ETSITS 129 198-6 V6.6.1 



(2006-07) 



Technical Specification 



Universal Mobile Telecommunications System (UMTS); 

Open Service Access (OSA) 

Application Programming Interface (API); 

Part 6: Mobility Service Capability Feature (SCF) 

(3GPP TS 29.198-06 version 6.6.1 Release 6) 



3ji^ 




U 



3GPP TS 29.1 98-06 version 6.6.1 Release 6 1 ETSI TS 1 29 1 98-6 V6.6.1 (2006-07) 



Reference 



RTS/TSGC-05291 98-06V661 
Keywords 



UMTS 



ETSI 

650 Route des Lucioles 
F-06921 Sophia Antipolis Cedex - FRANCE 

Tel. : +33 4 92 94 42 00 Fax: +33 4 93 65 47 1 6 

Siret N ° 348 623 562 0001 7 - NAF 742 C 
Association a but non lucratif enregistree a la 
Sous-Prefecture de Grasse (06) N° 7803/88 



Important notice 



Individual copies of the present document can be downloaded from: 
http://www.etsi.orq 

The present document may be made available in more than one electronic version or in print. In any case of existing or 

perceived difference in contents between such versions, the reference version is the Portable Document Format (PDF). 

In case of dispute, the reference shall be the printing on ETSI printers of the PDF version kept on a specific network drive 

within ETSI Secretariat. 

Users of the present document should be aware that the document may be subject to revision or change of status. 

Information on the current status of this and other ETSI documents is available at 

http://portal.etsi.orq/tb/status/status.asp 

If you find errors in the present document, please send your comment to one of the following services: 

http://portal.etsi.orq/chaircor/ETSI support.asp 

Copyright Notification 

No part may be reproduced except as authorized by written permission. 
The copyright and the foregoing restriction extend to reproduction in all media. 

© European Telecommunications Standards Institute 2006. 
All rights reserved. 

DECT'^", PLUGTESTS™ and UMTS™ are Trade IVlarks of ETSI registered for the benefit of its IVIembers. 
TIPHON^" and the TIPHON logo are Trade Marks currently being registered by ETSI for the benefit of its Members. 
2QppTM |g g jracle Mark of ETSI registered for the benefit of its Members and of the 3GPP Organizational Partners. 



ETSI 



3GPP TS 29.1 98-06 version 6.6.1 Release 6 2 ETSI TS 1 29 1 98-6 V6.6.1 (2006-07) 



Intellectual Property Rights 



IPRs essential or potentially essential to the present document may have been declared to ETSI. The information 
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found 
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in 
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web 
server ( http://webapp.etsi.org/IPR/home.asp ). 

Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee 
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web 
server) which are, or may be, or may become, essential to the present document. 



Foreword 

This Technical Specification (TS) has been produced by ETSI 3rd Generation Partnership Project (3GPP). 

The present document may refer to technical specifications or reports using their 3GPP identities, UMTS identities or 
GSM identities. These should be interpreted as being references to the corresponding ETSI deliverables. 

The cross reference between GSM, UMTS, 3GPP and ETSI identities can be found under 
http://webapp.etsi.org/kev/quervform.asp . 



ETSI 



3GPP TS 29.198-06 version 6.6.1 Release 6 3 ETSI TS 129 198-6 V6.6.1 (2006-07) 



Contents 



Intellectual Property Rights 2 

Foreword 2 

Foreword 8 

Introduction 8 

1 Scope 10 

2 References 10 

3 Definitions and abbreviations 1 

3.1 Definitions 1 

3.2 Abbreviations 1 

4 Mobility SCF 1 

4.1 General requirements on support of methods 1 

5 Sequence Diagrams 1 

5.1 User Location Sequence Diagrams 1 

5.1.1 User Location Interrogation - Triggered Request 1 

5.1.2 User Location Interrogation - Periodic Request 12 

5.1.3 User Location Interrogation - Interactive Request 13 

5.2 User Location Camel Sequence Diagrams 14 

5.2.1 User Location Camel Interrogation - Triggered Request 14 

5.2.2 User Location Camel Interrogation - Periodic Request 15 

5.2.3 User Location Camel Interrogation - Interactive Request 16 

5.3 User Status Sequence Diagrams 17 

5.3.1 Triggered Reporting 17 

5.3.2 Interactive Request 18 

6 Class Diagrams 19 

6.1 User Location Class Diagrams 19 

6.2 User Location Camel Class Diagrams 20 

6.3 User Status Class Diagrams 21 

7 The Service Interface Specifications 22 

7.1 Interface Specification Format 22 

7.1.1 Interface Class 22 

7.1.2 Method descriptions 22 

7.1.3 Parameter descriptions 23 

7.1.4 State Model 23 

7.2 Base Interface 23 

7.2.1 Interface Class Iplnterface 23 

7.3 Service Interfaces 23 

7.3.1 Overview 23 

7.4 Generic Service Interface 23 

7.4.1 Interface Class IpService 23 

7.4.1.1 Method setCallbackO 24 

7.4.1.2 Method setCallbackWithSessionlDQ 24 

8 Mobility Interface Classes 24 

8.1 User Location Interface Classes 24 

8.1.1 Interface Class IpUserLocation 25 

8.1.1.1 Method locationReportReqO 25 

8.1.1.2 Method extendedLocationReportReqO 26 

8.1.1.3 Method periodicLocationReportingStartReqO 26 

8.1.1.4 Method periodicLocationReportingStopO 27 

8.1.1.5 Method «new» getNextPeriodicLocationRequest() 27 

8.1.2 Interface Class IpAppUserLocation 28 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 4 ETSI TS 129 198-6 V6.6.1 (2006-07) 

8.1.2.1 Method locationReportResQ 28 

8.1.2.2 MethodlocationReportErrO 28 

8.1.2.3 Method extendedLocationReportResQ 29 

8.1.2.4 Method extendedLocationReportErr() 29 

8.1.2.5 Method periodicLocationReportO 29 

8.1.2.6 Method periodicLocationReportErrO 30 

8.1.3 Interface Class IpTriggeredUserLocation 30 

8.1.3.1 Method triggeredLocationReportingStartReqO 30 

8.1.3.2 Method triggeredLocationReportingStopO 31 

8.1.3.3 Method «new» getNextTriggeredLocationRequest() 31 

8.1.4 Interface Class IpAppTriggeredUserLocation 32 

8.1.4.1 Method triggeredLocationReport() 32 

8.1.4.2 Method triggeredLocationReportErr() 33 

8.1.4.3 Method «new» triggeredReportingEnded() 33 

8.2 User Location Camel Interface Classes 33 

8.2.1 Interface Class IpUserLocationCamel 33 

8.2.1.1 Method locationReportReqO 34 

8.2.1.2 Method periodicLocationReportingStartReqO 34 

8.2.1.3 Method periodicLocationReportingStopO 35 

8.2.1.4 Method triggeredLocationReportingStartReqO 35 

8.2.1.5 Method triggeredLocationReportingStopO 36 

8.2.1.6 Method «new» getNextPeriodicLocationRequest() 36 

8.2.1.7 Method «new» getNextTriggeredLocationRequest() 37 

8.2.2 Interface Class IpAppUserLocationCamel 37 

8.2.2.1 Method locationReportResQ 38 

8.2.2.2 MethodlocationReportErrO 38 

8.2.2.3 Method periodicLocationReportO 39 

8.2.2.4 Method periodicLocationReportErrO 39 

8.2.2.5 Method triggeredLocationReport() 39 

8.2.2.6 Method triggeredLocationReportErr() 39 

8.2.2.7 Method «new» triggeredReportingEndedO 40 

8.3 User Status Interface Classes 40 

8.3.1 Interface Class IpAppUserStatus 40 

8.3.1.1 Method statusReportResO 41 

8.3.1.2 Method statusReportErrO 41 

8.3.1.3 Method triggeredStatusReportO 42 

8.3.1.4 Method triggeredStatusReportErrO 42 

8.3.1.5 Method «new» extendedStatusReportResO 42 

8.3.1.6 Method «new» extendedStatusReportErrO 42 

8.3.1.7 Method «new» extTriggeredStatusReportO 43 

8.3.1.8 Method «new» extTriggeredStatusReportErrO 43 

8.3.1.9 Method «new» triggeredReportingEndedO 43 

8.3.2 Interface Class IpUserStatus 43 

8.3.2.1 Method statusReportReqO 44 

8.3.2.2 Method triggeredStatusReportingStartReqO 45 

8.3.2.3 Method triggeredStatusReportingStopO 45 

8.3.2.4 Method «new» getNextTriggeredStatusRequestO 45 

8.3.2.5 Method «new» extendedStatusReportReqO 46 

8.3.2.6 Method «new» extTriggeredStatusReportingStartReqO 46 

8.3.2.7 Method «new» ext TriggeredStatusReportingStopO 47 

9 State Transition Diagrams 47 

9.1 User Location 47 

9.2 User Location Camel 47 

9.2.1 State Transition Diagrams for IpUserLocationCamel 47 

9.2.1.1 Active State 48 

9.3 User Status 48 

9.3.1 State Transition Diagrams for IpUserStatus 48 

9.3.1.1 Active State 49 

10 Service Properties 49 

10.1 Mobility Properties 49 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 5 ETSI TS 129 198-6 V6.6.1 (2006-07) 

Emergency Application Subtypes 49 

Value Added Application Subtypes 49 

PLMN Operator Application Subtypes 50 

Lawful Intercept Application Subtypes 50 

Altitude Obtainable 50 

Location Methods 50 

Priorities 50 

Max Interactive Requests 51 

Max Triggered Users 51 

Max Periodic Users 51 

Min Periodic Interval Duration 51 

Initial Report 51 

Max Life Time 51 

User Location Service Properties 51 

User Location Camel Service Properties 52 

User Status Service Properties 52 

Data Definitions 53 

Common Mobility Data Definitions 53 

TpGeographicalPosition 53 

TpLocationPriority 54 

TpLocationRequest 55 

TpLocationResponselndicator 55 

TpLocationResponseTime 55 

TpLocationType 55 

TpLocationUncertaintyShape 56 

TpMobilityDiagnostic 56 

TpMobilityError 57 

TpMobilityStopAssignmentData 57 

TpMobilityStopScope 57 

TpTerminalType 57 

User Location Data Definitions 58 

IpUserLocation 58 

IpUserLocationRef 58 

IpAppUserLocation 58 

IpAppUserLocationRef 58 

IpTriggeredUserLocation 58 

IpTriggeredUserLocationRef 58 

IpAppTriggeredUserLocation 58 

IpAppTriggeredUserLocationRef 58 

TpUlExtendedData 58 

TpUlExtendedDataSet 58 

TpUserLocationExtended 59 

TpUserLocationExtendedSet 59 

TpLocationTrigger 59 

TpLocationTriggerSet 59 

TpLocationTriggerCriteria 59 

TpUserLocation 59 

TpUserLocationSet 60 

TpTriggeredLocationRequestSetEntry 60 

TpTriggeredLocationRequestSet 60 

TpTriggeredLocationRequest 60 

TpPeriodicLocationRequestSetEntry 60 

TpPeriodicLocationRequestSet 60 

TpPeriodicLocationRequest 60 

User Location Camel Data Definitions 61 

IpUserLocationCamel 61 

IpUserLocationCamelRef 61 

IpAppUserLocationCamel 61 

IpAppUserLocationCamelRef 61 

TpLocationCelllDOrLAI 61 

TpLocationTriggerCamel 61 



£75/ 



10.1.1 


10.1.2 


10.1.3 


10.1.4 


10.1.5 


10.1.6 


10.1.7 


10.1.8 


10.1.9 


10.1.10 


10.1.11 


10.1.12 


10.1.13 


10.2 


10.3 


10.4 




I 




1 




1.1 




1.2 




1.3 




1.4 




1.5 




1.6 




1.7 




1.8 




1.9 




1.10 




1.11 




1.12 




2 




2.1 




2.2 




2.3 




2.4 




2.5 




2.6 




2.7 




2.8 




2.9 




2.10 




2.11 




2.12 




2.13 




2.14 




2.15 




2.16 




2.17 




2.18 




2.19 




2.20 




2.21 




2.22 




2.23 




3 




3.1 




3.2 




3.3 




3.4 




3.5 




3.6 



3GPP TS 29.198-06 version 6.6.1 Release 6 6 ETSI TS 129 198-6 V6.6.1 (2006-07) 

11.3.7 TpUserLocationCamel 62 

11.3.8 TpUserLocationCamelSet 62 

11.4 User Location Emergency Data Definitions 62 

11.4.1 IpUserLocationEmergency 62 

11.4.2 IpUserLocationEmergencyRef 62 

11.4.3 IpAppUserLocationEmergency 62 

11.4.4 IpAppUserLocationEmergencyRef 62 

11.4.5 TplMEl 62 

11.4.6 TpNaESRD 62 

11.4.7 TpNaESRK 63 

11.4.8 TpUserLocationEmergencyRequest 63 

11.4.9 TpUserLocationEmergency 63 

11.4.10 TpUserLocationEmergencyTrigger 64 

11.5 User Status Data Definitions 64 

11.5.1 IpUserStatus 64 

11.5.2 IpUserStatusRef 64 

11.5.3 IpAppUserStatus 64 

11.5.4 IpAppUserStatusRef 64 

11.5.5 TpUserStatus 64 

11.5.6 TpUserStatusSet 64 

11.5.7 TpUserStatusIndicator 64 

11.5.8 TpTriggeredStatusRequestSetEntry 65 

11.5.9 TpTriggeredStatusRequestSet 65 

11.5.10 TpTriggeredStatusRequest 65 

11.5.11 TpUserStatusExtended 65 

11.5.12 TpUserStatusExtendedSet 65 

11.5.13 TpUserStatuslndicatorExtended 66 

11.5.14 TpAuthStatuslndicator 66 

11.5.15 TpUserlnfo 66 

11.5.16 TpNetworkStatuslndicator 66 

11.5.17 TpAccessTechnology 66 

11.5.18 TpRoamingStatus 66 

11.6 User Binding Data Definitions 67 

11.6.1 TpBindingSet 67 

11.6.2 TpBindingEntrySet 67 

11.6.3 TpBindingEntry 67 

11.6.4 TpBindingEntry Type 67 

11.6.5 TpBindingNotificationCriteriaSet 67 

11.6.6 TpBindingNotificationCriteria 68 

11.6.7 TpBindingNotificationCriteriaType 68 

11.7 Units and Validations of Parameters 68 

12 Exception Classes 69 

Annex A (normative) : OMG IDL Description of Mobility SCF 70 

Annex B (informative) : W3C WSDL Description of Mobility SCF 71 

Annex C (informative): Java API Description of the Mobility SCFs 72 

Annex D (informative) : Description of Mobility SCF for 3GPP2 cdma2000 networks 73 

D.l General Exceptions 73 

D.2 Specific Exceptions 73 

D.2.1 Clause 1: Scope 73 

D.2.2 Clause 2: References 73 

D.2. 3 Clause 3: Definitions and abbreviations 73 

D.2.4 Clause 4: Mobility SCF 73 

D.2. 5 Clause 5: Sequence Diagrams 73 

D.2.6 Clause 6 Class Diagrams 74 

D.2. 7 Clause 7: The Service Interface Specifications 74 

D.2.8 Clause 8: Mobility Interface Classes 74 



£75/ 



3GPP TS 29.1 98-06 version 6.6.1 Release 6 7 ETSI TS 1 29 1 98-6 V6.6.1 (2006-07) 

D.2.9 Clause 9: State Transition Diagrams 74 

D.2.10 Clause 10: Service Properties 74 

D.2.11 Clause 11 : Data Definitions 74 

D.2.12 Clause 12: Exception Classes 74 

D.2.13 Annex A (normative): OMGIDL Description of Mobility SCF 74 

D.2.14 AnnexB(informative):W3CWSDL Description of Mobility SCF 74 

D.2.15 Annexe (informative): Java™ API Description of Mobility SCF 74 

Annex E (informative): Change history 75 

History 76 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 



ETSI TS 129 198-6 V6.6.1 (2006-07) 



Foreword 



This Technical Specification has been produced by the 3' Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 
where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



The present document is part 6 of a multi-part TS covering the 3' Generation Partnership Project: Technical 
Specification Group Core Network and Terminals; Open Service Access (OSA); Application Programming Interface 
(API), as identified below. The API specification (3GPP TS 29.198) is structured in the following Parts: 



Parti 
Part 2 
Part 3 
Part 4 



Part 5: 
Part 6: 

Part 7: 
Part 8: 
Part 9: 
Part 10 
Part II 
Part 12 
Part 13 
Part 14 
Part 15 



"Overview"; 

"Common Data Definitions"; 

"Framework"; 

"Call Control"; 

Sub-part 1: "Call Control Common Definitions"; 

Sub-part 2: "Generic Call Control SCF"; 

Sub-part 3: "Multi-Party Call Control SCF"; 

Sub-part 4: "Multi-Media Call Control SCF"; 

Sub-part 5: "Conference Call Control SCF"; 

"User Interaction SCF"; 

"Mobility SCF"; 

"Terminal CapabiHties SCF"; 

"Data Session Control SCF"; 

"Generic Messaging SCF"; 

"Connectivity Manager SCF"; 

"Account Management SCF"; 

"Charging SCF". 

"Policy Management SCF"; 

"Presence and Availability Management SCF"; 

"Multi Media Messaging SCF"; 



(not part of 3GPP Release 6) 



(not part of 3GPP Release 6) 
(not part of 3GPP Release 6) 



(new in Release 6) 



The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 
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Table: Overview of the OSA APIs & Protocol Mappings 29.198 & 29.998-faniily 



OSA API specifications 29.198-family 


OSA API IVIapping - 29.998-family 


29.198-01 


Overview 


29.998-01 


Overview 


29.198-02 


Common Data Definitions 


29.998-02 


Not Applicable 


29.198-03 


Framework 


29.998-03 


Not Applicable 


Call 
Control 
(CC) SCF 


29.198- 
04-1 

Common 
CC data 
definitions 


29.198- 
04-2 
Generic 
CCSCF 


29.198- 
04-3 
Multi- 
Party CC 
SCF 


29.198- 
04-4 
Multi- 
media CC 
SCF 


29.998-04-1 


Generic Call Control - CAP mapping 


29.998-04-2 


Generic Call Control - INAP mapping 


29.998-04-3 


Generic Call Control - Megaco mapping 


29.998-04-4 


Multiparty Call Control - ISC mapping 


29.198-05 


User Interaction SCF 


29.998-05-1 


User Interaction - CAP mapping 


29.998-05-2 


User Interaction - INAP mapping 


29.998-05-3 


User Interaction - Megaco mapping 


29.998-05-4 


User Interaction - SMS mapping 


29.198-06 


Mobility SCF 


29.998-06 


User Status and User Location - MAP mapping 


29.198-07 


Terminal Capabilities SCF 


29.998-07 


Not Applicable 


29.198-08 


Data Session Control SCF 


29.998-08 


Data Session Control - CAP mapping 


29.198-09 


Generic Messaging SCF 


29.998-09 


Not Applicable 


29.198-10 


Connectivity Manager SCF 


29.998-10 


Not Applicable 


29.198-11 


Account Management SCF 


29.998-11 


Not Applicable 


29.198-12 


Charging SCF 


29.998-12 


Not Applicable 


29.198-13 


Policy Management SCF 


29.998-13 


Not Applicable 


29.198-14 


Presence & Availability Management SCF 


29.998-14 


Not Applicable 


29.198-15 


Multi-media Messaging SCF 


29.998-15 


Not Applicable 
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Scope 



The present document is Part 6 of the Stage 3 specification for an Apphcation Programming Interface (API) for Open 
Service Access (OS A). 

The OSA specifications define an architecture that enables application developers to make use of network functionality 
through an open standardised interface, i.e. the OSA APIs. The concepts and the functional architecture for the OSA are 
contained in 3GPP TS 23.198 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

The present document specifies the Mobility Service Capability Feature (SCF) aspects of the interface. All aspects of 
the Mobility SCF are defined here, these being: 

Sequence Diagrams 

Class Diagrams 

Interface specification plus detailed method descriptions 

State Transition diagrams 

Data definitions 

IDL Description of the interfaces 

WSDL Description of the interfaces 

Reference to the JavaT"^ API description of the interfaces 

The process by which this task is accomplished is through the use of object modelling techniques described by the 
Unified Modelling Language (UML). 

This specification has been defined jointly between 3GPP TSG CT WG5, ETSI TISPAN and the Parlay Group, in co- 
operation with a number of JAIN^^ Community member companies. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 29.198-01: "Open Service Access (OSA) Application Programming Interface (API); 

Part 1: Overview". 

[2] 3GPP TS 22.127: "Service Requirement for the Open Services Access (OSA); Stage 1". 

[3] 3GPP TS 23.198: "Open Service Access (OSA); Stage 2". 

[4] 3GPP TS 29.002: "Mobile Application Part (MAP) specification". 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 11 ETSI TS 129 198-6 V6.6.1 (2006-07) 

3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in TS 29.198-1 [1] apply. 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in TS 29.198-1 [1] apply. 

4 IVIobility SCF 

The following clauses describe each aspect of the Mobility Service Capability Feature (SCF). 
The order is as follows: 

• The Sequence diagrams give the reader a practical idea of how each of the SCFs is implemented. 

• The Class relationships clause shows how each of the interfaces applicable to the SCF, relate to one another. 

• The Interface specification clause describes in detail each of the interfaces shown within the Class diagram part. 

• The State Transition Diagrams (STD) show the transition between states in the SCF. The states and transitions 
are well-defined; either methods specified in the Interface specification or events occurring in the underlying 
networks cause state transitions. 

• The Data Definitions clause shows a detailed expansion of each of the data types associated with the methods 
within the classes. Note that some data types are used in other methods and classes and are therefore defined 
within the Common Data types part of this specification. 

4.1 General requirements on support of methods 

An implementation of this API which supports or implements a method described in the present document, shall 
support or implement the functionality described for that method, for at least one valid set of values for the parameters 
of that method. 

Where a method is not supported by an implementation of a Service interface, the exception 
P_METHOD_NOT_SUPPORTED shall be returned to any call of that method. 

Where a method is not supported by an implementation of an Application interface, a call to that method shall be 
possible, and no exception shall be returned. 

5 Sequence Diagrams 

5.1 User Location Sequence Diagrams 

5.1 .1 User Location Interrogation - Triggered Request 

The following sequence diagram shows how an application requests triggered location reports from the User Location 
service. When users location changes, the service reports this to the application. 
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IpAppTriqqeredU ser Local ion 



IpTriqqeredUserLocation 



1 : triggeredLocationReportingStartReq( 



^ 



n 



1^ 



1^ 



2: triggeredLocationReport( ) 



3: triggeredLocationReport( 



New reports are sent until the ^ 
triggered reporting is stopped 



4: triggeredLocationReportingStop( 



^, 



1: This message is used to start triggered location reporting for one or several users. 

2: When the trigger condition is fulfilled then this message passes the location of the affected user to its callback 
object. 

3: This is repeated until the application stops triggered location reporting (see next message). 

4: This message is used to stop triggered location reporting. 



5.1 .2 User Location Interrogation - PeriocJic Request 

The following sequence diagram shows how an application requests periodic location reports from the User Location 
service. 
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IpAppUserLocation 



(f- 



Q^ 



1: periodicLocationReportingStartReq( 



2: periodicLocationReport( 



3: periodicLocationReport( 



New reports are sent until the 
periodic reporting is stopped 



4: periodicLocationReportingStop( ) 



IpUserLocation 



^ 



n 



^ 



1: This message is used to start periodic location reporting for one or several users. 

2: This message passes the location of one or several users to its callback object. 

3: This message passes the location of one or several users to its callback object. 

This is repeated at regular intervals until the application stops periodic location reporting (see next message). 

4: This message is used to stop periodic location reporting. 

5.1 .3 User Location Interrogation - Interactive Request 

The following sequence diagram shows how an application requests a location report from the User Location service. 
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IpAppUserLocation 



IpUserLocation 



1 : locationReportReq( ) 



^r 



2: locationReportRes( 



1 : This message is used to request the location of one or several users. 

2: This message passes the result of the location request for one or several users to its callback object. 



5.2 User Location Camel Sequence Diagrams 

5.2.1 User Location Camel Interrogation - Triggered Request 

The following sequence diagram shows how an application requests triggered location reports from the User Location 
Camel service. When users location changes, the service reports this to the application. 
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IpAppUserLocationCamel 



IpUserLocationCamel 



1: triggeredLocationReportingStartReq( ) 



1^ 



2: triggeredLocationReport( 



1^ 



3: triggeredLocationReport( 



New reports are sent until the ^ 
triggered reporting is stopped 



4: triggeredLocationReportingStop{ [ 



^r 



D 



1: This message is used to start triggered location reporting for one or several users. 

2: When the trigger condition is fulfilled then this message passes the location of the affected user to its callback 
object. 

3: This is repeated until the application stops triggered location reporting (see next message). 

4: This message is used to stop triggered location reporting. 



5.2.2 User Location Camel Interrogation - PeriocJic Request 

The following sequence diagram shows how an application requests periodic location reports from the User Location 
Camel service. 
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IpAppUserLocationCamel 



IpUserLocationCamel 



1: periodicLocationReportingStartReq( ) 



(r 



2: periodicLocationReport{ 



3: periodicLocationReport{ 



New reports are sent until the 
periodic reporting is stopped 



4: periodicLocationReportingStop{ ] 



^ 



1: This message is used to start periodic location reporting for one or several users. 

2: This message passes the location of one or several users to its callback object. 

3: This message passes the location of one or several users to its callback object. 

This is repeated at regular intervals until the application stops periodic location reporting (see next message). 

4: This message is used to stop periodic location reporting. 

5.2.3 User Location Camel Interrogation - Interactive Request 

The following sequence diagram shows how an application requests a location report from the User Location Camel 
service. 
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IpAppUserLocationCamel 



IpUserLocationCamel 



1: locationReportReq{ 



2: locationReportRes{ 



1 : This message is used to request the location of one or several users. 

2: This message passes the result of the location request for one or several users to its callback object. 



5.3 User Status Sequence Diagrams 
5.3.1 Triggered Reporting 

The following sequence diagram shows how an application requests triggered status reports from the Status Location 
service. When user's status changes, the service reports this to the application. 
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IpAppUserStatus 



IpUserStatus 



1 : triggeredStatusReportingStartReq{ 




New reports are sent until the 
triggered reporting is stopped 



4: triggeredStatusReportingStop( 



1: This message is used to start triggered status reporting for one or several users. 

2: When a user's status changes, this message passes the status to its callback object. 

3: This is repeated until the application stops triggered status reporting (see next message). 

4: This message is used to stop triggered status reporting. 

5.3.2 Interactive Request 

The following sequence diagram shows how an application requests a status report from the User Status service. 
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IpAppUserStatus 



IpUserStatus 



1: statusReportReq( 



^! 



n 



(T 



2: statusReportRes{ 



1 : This message is used to request the status of one or several users. 

2: This message passes the result of the status request to its callback object. 



6 Class Diagrams 

6.1 User Location Class Diagrams 

This class diagram shows the relationship between the interfaces in the User Location service. IpTriggeredUserLocation 
inherits from IpUserLocation, and IpAppTriggeredUserLocation inherits from IpAppUserLocation. 
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<<lnterface>> 
IpAppTriggeredUserLocation 

(from ul) 

^triggeredLocationReportO 
I %riggeredLocationReportErr() 
U<<new>> triggetBdReportingEndedO 



<<lnterface>> 
IpAppUserLocation 

(from ul) 



BocationReportResQ 

''locat ion Report Err{) 

^extendedLocationReportResO 

^extendedLocationReportErrO 

♦periodicLocationReportO 

♦periodicLocationReportErrO 



<<lnterface>> 
IpUserLocation 

(from ul) 



'^location Report Req() 
^extendedLocationReportReqO 
^periodicLocationReportingStartReqO 
^periodicLocationReportingStopO 
^<<new>> getNextPeriodicLocationRequestO 



<<lnterface>> 
IpTriggeredUserLocation 

(from ul) 

^riggeredLocation Report ingStartReqO 
^riggeredLocationReportingStopO 
4<<new>> getNextTriggeredLocationRequestO 



Figure: User Location Class Diagram 



6.2 User Location Camel Class Diagrams 

This class diagram shows the interfaces for the User Location Camel service. 
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<<lnterface>> 
IpAppUserLocationCamel 

(from ulc) 

^location Report Res 

^location Report Err{) 

l^periodicLocationReportO 

|*periodicLocationReportErr() 

^triggeredLocationReportO 

l*triggeredLocationReportErr() 

B^<<new>> triggeredReportingEndedO 



<<lnterface>> 
IpUserLocationCamel 

(from ulc) 



^locationReportReqO 
B^periodicLocationReportingStartReqO 
^periodic Locat ion ReportingStopO 
l^triggeredLocationReportingStartReqO 
B^triggeredLocationReportingStopO 
^«new>> get Next Period icLocationRequestO 
B^«new» getNextTriggeredLocationRequestO 



Figure: User Location Camel Class Diagram 



6.3 User Status Class Diagrams 

This class diagram shows the interfaces for the User Status service. 
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<<lnterface>> 
IpAppUserStatus 

(tram u s) 



^Status Report Res 

^statusReportErrO 

^riggeredStatusReportO 
^^riggeredStat us Report Err() 
^<<new>> extendedStatus Report Res() 
'^<<new>> extendedStatus Report Err() 

^<<new>> extTriggeredStatus Report 

^<<new>> extTriggeredStatus Report Err() 
,'^<<new>> triggeredReportingEndedO 



<<lnterface>> 
IpUserStatus 

(from us) 

|statusReportReq() 

PtriggeredStatus Report ingStartReqO 

|triggeredStatus Report ingStopO 

J<<new» getNextTriggeredStatusRequestO 

|<<new» extendedStatus Report Req() 

|<<new» extTriggeredStatus Report ingStartReqO 

|<<new» extTriggeredStatus Report ingStopO 



Figure: User Status Class Diagram 



7 The Service Interface Specifications 

7.1 Interface Specification Format 

This clause defines the interfaces, methods and parameters that form a part of the API specification. The Unified 
Modelling Language (UML) is used to specify the interface classes. The general format of an interface specification is 
described below. 

7.1.1 Interface Class 

This shows a UML interface class description of the methods supported by that interface, and the relevant parameters 
and types. The Service and Framework interfaces for enterprise-based client applications are denoted by classes with 
name Ip<name>. The callback interfaces to the applications are denoted by classes with name IpApp<name>. For 
the interfaces between a Service and the Framework, the Service interfaces are typically denoted by classes with name 
IpSvc<name>, while the Framework interfaces are denoted by classes with name IpFw<name>. 



7.1.2 



Method descriptions 



Each method (API method "call") is described. Both synchronous and asynchronous methods are used in the API. 
Asynchronous methods are identified by a 'Req' suffix for a method request, and, if applicable, are served by 
asynchronous methods identified by either a 'Res' or 'Err' suffix for method results and errors, respectively. To handle 
responses and reports, the application or service developer must implement the relevant IpApp<name> or 
IpSvc<name> interfaces to provide the callback mechanism. 
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7.1.3 Parameter descriptions 

Each method parameter and its possible values are described. Parameters described as 'in' represent those that must have 
a value when the method is called. Those described as 'out' are those that contain the return result of the method when 
the method returns. 

7.1.4 State Model 

If relevant, a state model is shown to illustrate the states of the objects that implement the described interface. 

7.2 Base Interface 

7.2.1 Interface Class Iplnterface 

All application, framework and service interfaces inherit from the following interface. This API Base Interface does not 
provide any additional methods. 



«lnterface» 
Iplnterface 



7.3 Service Interfaces 
7.3.1 Overview 

The Service Interfaces provide the interfaces into the capabilities of the underlying network - such as call control, user 
interaction, messaging, mobility and connectivity management. 

The interfaces that are implemented by the services are denoted as 'Service Interface'. The corresponding interfaces that 
must be implemented by the application (e.g. for API callbacks) are denoted as 'Application Interface'. 

7.4 Generic Service Interface 
7.4.1 Interface Class IpService 

Inherits from: Iplnterface 

All service interfaces inherit from the following interface. 



«lnterface» 
IpService 



setCallback (applnterface : in IplnterfaceRef) : void 

setCallbackWitlnSessionlD (applnterface : in IplnterfaceRef, sessionID : in TpSessionID) : void 
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7.4.1.1 Method setCallback() 

This method specifies the reference address of the callback interface that a service uses to invoke methods on the 
application. It is not allowed to invoke this method on an interface that uses SessionlDs. Multiple invocations of this 
method on an interface shall result in multiple callback references being specified. The SCS shall use the most recent 
callback interface provided by the application using this method. In the event that a callback reference fails or is no 
longer available, the next most recent callback reference available shall be used. 

Parameters 

applnterface : in IpInterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

Raises 

TpCommonExceptions , P_INVALID_INTERFACE_TYPE 



7.4.1.2 Method setCallbackWithSessionlD() 

This method specifies the reference address of the application's callback interface that a service uses for interactions 
associated with a specific session ID: e.g. a specific call, or call leg. It is not allowed to invoke this method on an 
interface that does not use SessionlDs. Multiple invocations of this method on an interface shall result in multiple 
callback references being specified. The SCS shall use the most recent callback interface provided by the application 
using this method. In the event that a callback reference fails or is no longer available, the next most recent callback 
reference available shall be used. 

Parameters 

applnterface : in IpInterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

sessionID : in TpSessionID 

Specifies the session for which the service can invoke the application's callback interface. 

Raises 

TpCommonExceptions, P_INVALID_SESSION_ID, P_INVALID_INTERFACE_TYPE 



8 Mobility Interface Classes 

8.1 User Location Interface Classes 

The User Location service (UL) provides a general geographic location service. UL has functionality to allow 
applications to obtain the geographical location and the status of fixed, mobile and IP based telephony users. 

UL is supplemented by User Location Camel service (ULC) to provide information about network related information. 
There is also some specialised functionality to handle emergency calls in the User Location Emergency service (ULE). 

The UL service provides the IpUserLocation and IpTriggeredUserLocation interfaces. Most methods are asynchronous, 
in that they do not lock a thread into waiting whilst a transaction performs. In this way, the client machine can handle 
many more calls, than one that uses synchronous message calls. To handle responses and reports, the developer must 
implement IpAppUserLocation and IpAppTriggeredUserLocation interfaces to provide the callback mechanism. 
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When periodic or triggered location reporting is used, errors may be reported either when the recurrent reporting is 
requested, as an error per user in reports or in the corresponding err-method when the error concerns all subscribers in 
an assignment. 

8.1 .1 Interface Class IpUserLocation 

Inherits from: IpService. 

This interface is the 'service manager' interface for the User Location Service. 

The user location interface provides the management functions to the user location service. The application programmer 
can use this interface to obtain the geographical location of users. 

This interface, or IpTriggeredUserLocation, shall be implemented by a User Location SCF as a minimum requirement. 

The locationReportReqO method, or the extendedLocationReportReqO method, or both the 
periodicLocationReportingStartReqO and periodicLocationReportingStopO methods shall be implemented as a 
minimum requirement, if this interface is implemented. 



«lnterface» 
IpUserLocation 



locationReportReq (appLocation : in IpAppUserLocationRef, users : in TpAddressSet) : TpAssignmentID 

extendedLocationReportReq (appLocation : in IpAppUserLocationRef, users : in TpAddressSet, request : in 
TpLocation Request) : TpAssignmentID 

periodicLocationReportingStartReq (appLocation : in IpAppUserLocationRef, users : in TpAddressSet, 
request : in TpLocationRequest, reportinglnterval : in TpDuration) : TpAssignmentID 

periodicLocationReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 

«new» getNextPeriodicLocationRequest (reset : in TpBoolean) : TpPeriodicLocationRequestSetEntry 



8.1 .1 .1 Method locationReportReqO 

Request of a report on the location for one or several users. 

Returns: assignmentld. 

Specifies the assignment ID of the location-report request. 

Parameters 

appLocation : in IpAppUserLocationRef 

Specifies the application interface for callbacks from the User Location service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 
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Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_APPLICATION_NOT_ACTIVATED , 
P_INFORMATION_NOT_AVAILABLE , P_INVALID_INTERFACE_TYPE 



8.1.1.2 Method extendedLocation ReportReq() 

Advanced request of report on the location for one or several users. 

Returns: assignmentld. 

Specifies the assignment ID of the extended location-report request. 

Parameters 

appLocation : in IpAppUserLocationRef 

Specifies the application interface for callbacks from the User Location service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported 

request : in TpLocationRequest 

Specifies among others the requested location type, accuracy, response time and priority. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_APPLICATION_NOT_ACTIVATED , 
P_REQUESTED_ACCURACY_CANNOT_BE_DELIVERED, 
P_REQUESTED_RESPONSE_TIME_CANNOT_BE_DELIVERED, 
P_INFORMATION_NOT_AVAILABLE , P_INVALID_INTERFACE_TYPE 



8.1 .1 .3 Method periodicLocationReportingStartReq() 

Request of periodic reports on the location for one or several users. 

Returns: assignmentld. 

Specifies the assignment ID of the periodic location-reporting request. 

Parameters 

appLocation : in IpAppUserLocationRef 

Specifies the application interface for callbacks from the User Location service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 
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request : in TpLocationRequest 

Specifies among others the requested location type, accuracy, response time and priority. 

reportinglnterval : in TpDuration 

Specifies the requested interval in milliseconds between the reports. 

Returns 

TpAs s ignmen t I D 

Raises 

TpCommonExcept ions , P_INVALID_REPORTING_INTERVAL , 
P_REQUESTED_ACCURACY_CANNOT_BE_DELIVERED, 
P_REQUESTED_RESPONSE_TIME_CANNOT_BE_DELIVERED, 
P_APPLICATION_NOT_ACTIVATED , P_INFORMATION_NOT_AVAILABLE , 
P INVALID INTERFACE TYPE 



8.1.1.4 Method periodicLocation ReportingStop() 

Termination of periodic reports on the location for one or several users. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 

8.1 .1 .5 Method «new» getNextPeriodicLocationRequestQ 

This method is used by the application to query the request set created with periodicLocationReportingStartReq. Since a 
lot of data can potentially be returned (which might cause problem in the middleware), this method must be used in an 
iterative way. Each method invocation may return part of the total set of requests if the set is too large to return it at 
once. The reset parameter permits the application to indicate whether an invocation to getNextPeriodicLocationRequest 
is requesting more requests from the total set of requests or is requesting that the total set of requests shall be returned 
from the beginning. 

Returns the set of requests and an indication whether all off the requests have been obtained or if more requests are 
available that have not yet been obtained by the application. 

Note that the (maximum) number of items provided to the application is determined by the gateway. 

Parameters 

reset : in TpBoolean 

TRUE: indicates that the application is intended to obtain the set of requests starting at the beginning. 

FALSE: indicates that the application requests the next set of requests that have not (yet) been obtained since the last 
call to this method with this parameter set to TRUE. 

The first time this method is invoked, reset shall be set to TRUE. Following the receipt of a final indication, for the next 
call to this method reset shall be set to TRUE. P_TASK_REFUSED may be thrown if these conditions are not met. 
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Returns 
TpPeriodicLocationRequestSetEntry 

Raises 
TpCommonExceptions 



8.1 .2 Interface Class IpAppUserLocation 

Inherits from: Iplnterface. 

The user-location application interface is implemented by the client appUcation developer and is used to handle user 
location request responses. 



«lnterface» 
IpAppUserLocation 



locationReportRes (assignmentid : in TpAssignmentID, locations : in TpUserLocationSet) : void 

locationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

extendedLocationReportRes (assignmentid : in TpAssignmentID, locations : in 
TpUserLocationExtendedSet) : void 

extendedLocationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

periodicLocationReport (assignmentid : in TpAssignmentID, locations : in TpUserLocationExtendedSet) : 
void 

periodicLocationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 



8.1.2.1 Method location ReportResQ 

A report containing locations for one or several users is delivered. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the location-report request. 

locations : in TpUserLocationSet 

Specifies the location(s) of one or several users. 



8.1.2.2 Method location ReportErr() 

This method indicates that the location report request has failed. 
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Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed location report request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.1.2.3 



Method extendedLocation ReportResO 



A report containing extended location information for one or several users is delivered. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the extended location-report request. 

locations : in TpUserLocationExtendedSet 

Specifies the location(s) of one or several users. 



8.1.2.4 Method extendedLocation ReportErr() 

This method indicates that the extended location report request has failed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed extended location report request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.1.2.5 



Method periodicLocationReportO 



A report containing periodic location information for one or several users is delivered. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the periodic location-reporting request. 

locations : in TpUserLocationExtendedSet 

Specifies the location(s) of one or several users. 
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8.1.2.6 Method periodicLocationReportErr() 

This method indicates that a requested periodic location report has failed. Note that errors only concerning individual 
users are reported in the ordinary periodicLocationReport() message. 

Parameters 

assignmentid : in TpAssignmentlD 

Specifies the assignment ID of the failed periodic location reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.1 .3 Interface Class IpTriggeredUserLocation 

Inherits from: IpUserLocation. 

This interface can be used as an extended version of the User Location: Service Interface. 

The triggered user location interface represents the interface to the triggered user location functions. The application 
programmer can use this interface to request user location reports that are triggered by location change. 

This interface, or IpUserLocation, shall be implemented by a User Location SCF as a minimum requirement. 

The triggeredLocationReportingStartReqO and triggeredLocationReportingStopO methods shall be implemented as a 
minimum requirement. An implementation of IpTriggeredUserLocation is not required to implement the minimum 
mandatory methods of IpUserLocation. 



«lnterface» 
IpTriggeredUserLocation 



triggeredLocationReportingStartReq (appLocation : in IpAppTriggeredUserLocationRef, users : in 

TpAddressSet, request : in TpLocation Request, triggers : in TpLocationTriggerSet) : TpAssignmentlD 

triggeredLocationReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 

«new» getNextTriggeredLocationRequest (reset : in TpBoolean) : TpTriggeredLocationRequestSetEntry 



8.1 .3.1 Method triggeredLocationReportingStartReq() 

Request for user location reports when the location is changed (reports are triggered by location change). 

Returns: assignmentid. 

Specifies the assignment ID of the triggered location-reporting request. 
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Parameters 

appLocation : in IpAppTriggeredUserLocationRef 

Specifies the application interface for callbacks from the User Location service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 

request : in TpLocationRequest 

Specifies among others the requested location type, accuracy, response time and priority. 

triggers : in TpLocationTriggerSet 

Specifies the trigger conditions. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExcept ions , P_REQUESTED_ACCURACY_CANNOT_BE_DELIVERED , 
P_REQUESTED_RESPONSE_TIME_CANNOT_BE_DELIVERED, 
P_TRIGGER_CONDITIONS_NOT_SUBSCRIBED , P_UNICNOWN_SUBSCRIBER, 
P_APPLICATION_NOT_ACTIVATED , P_INFORMATION_NOT_AVAILABLE , 
P INVALID INTERFACE TYPE 



8.1 .3.2 Method triggeredLocationReportingStop() 

Stop triggered user location reporting. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 

8.1 .3.3 Method «new» getNextTriggeredLocationRequestQ 

This method is used by the application to query the request set created with triggeredLocationReportingStartReq. Since 
a lot of data can potentially be returned (which might cause problem in the middleware), this method must be used in an 
iterative way. Each method invocation may return part of the total set of requests if the set is too large to return it at 
once. The reset parameter permits the application to indicate whether an invocation to 

getNextTriggeredLocationRequest is requesting more requests from the total set of requests or is requesting that the 
total set of requests shall be returned from the beginning. 

Returns the set of requests and an indication whether all off the requests have been obtained or if more requests are 
available that have not yet been obtained by the application. 

Note that the (maximum) number of items provided to the application is determined by the gateway. 
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Parameters 

reset : in TpBoolean 

TRUE: indicates that the apphcation is intended to obtain the set of requests starting at the beginning. 

FALSE: indicates that the apphcation requests the next set of requests that have not (yet) been obtained since the last 
call to this method with this parameter set to TRUE. 

The first time this method is invoked, reset shall be set to TRUE. Following the receipt of a final indication, for the next 
call to this method reset shall be set to TRUE. P_TASK_REFUSED may be thrown if these conditions are not met. 

Returns 
TpTriggeredLocationRequestSetEntry 

Raises 
TpCommonExceptions 



8.1 .4 Interface Class IpAppTriggeredUserLocation 

Inherits from: IpAppUserLocation. 

This interface must be used as a specialised version of the User Location: Application Interface if the Triggered User 
Location: Service Interface is used. 

The triggered user location application interface is implemented by the client application developer and is used to 
handle triggered location reports. 



«lnterface» 
IpAppTriggeredUserLocation 



triggeredLocationReport (assignmentid : in TpAssignmentID, location : in TpUserLocationExtended, 
criterion : in TpLocationTriggerCriteria) : void 

triggeredLocationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

«new» triggeredReportingEnded (assignmentid : in TpAssignmentID) : void 



8.1 .4.1 Method triggeredLocationReport() 

A triggered report containing location for a user is delivered. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered location-reporting request. 

location : in TpUserLocationExtended 

Specifies the location of the user. 
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criterion : in TpLocationTriggerCriteria 

Specifies the criterion that triggered the report. 



8.1 .4.2 Method triggeredLocationReportErrQ 

This method indicates that a requested triggered location report has failed. Note that errors only concerning individual 
users are reported in the ordinary triggeredLocationReport() message. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed triggered location reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.1 .4.3 Method «new» triggeredReportingEnded() 

The user status or user location triggering has stopped because the max life time allowed for this triggering has 
exceeded. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered request. 

8.2 User Location Camel Interface Classes 

The ULC provides location information, based on network-related information, rather than the geographical co- 
ordinates that can be retrieved via the general User Location Service. 

Using the ULC functions, an application programmer can request the VLR Number, the location Area Identification and 
the Cell Global Identification and other mobile-telephony-specific location information. 

The ULC provides the IpUserLocationCamel interface. Most methods are asynchronous, in that they do not lock a 
thread into waiting whilst a transaction performs. In this way, the client machine can handle many more calls, than one 
that uses synchronous message calls. To handle responses and reports, the developer must implement 
IpAppUserLocationCamel interface to provide the callback mechanism. 

8.2.1 Interface Class IpUserLocationCamel 

Inherits from: IpService. 

This interface is the 'service manager' interface for ULC. 

This interface shall be implemented by a User Location Camel SCF. 

The locationReportReqO method, or both the periodicLocationReportingStartReqO and 
periodicLocationReportingStopO methods, or both the triggeredLocationReportingStartReqO and 
triggeredLocationReportingStopO methods shall be implemented as a minimum requirement. 
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«lnterface» 
IpUserLocationCamel 



locationReportReq (appLocationCamel : in IpAppUserLocationCamelRef, users : in TpAddressSet) : 
TpAssignmentID 

periodicLocationReportingStartReq (appLocationCamel : in IpAppUserLocationCamelRef, users : in 
TpAddressSet, reportinglnterval : in TpDuration) : TpAssignmentID 

periodicLocationReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 

triggeredLocationReportingStartReq (appLocationCamel : in IpAppUserLocationCamelRef, users : in 
TpAddressSet, trigger : in TpLocationTriggerCamel) : TpAssignmentID 

triggeredLocationReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 

«new» getNextPeriodicLocationRequest (reset : in TpBoolean) : TpPeriodicLocationRequestSetEntry 

«new» getNextTriggeredLocationRequest (reset : in TpBoolean) : TpTriggeredLocationRequestSetEntry 



8.2.1.1 Method locationReportReq() 

Request for mobile-related location information on one or several camel users. 

Returns: assignmentld. 

Specifies the assignment ID of the location-report request. 

Parameters 

appLocationCamel : in IpAppUserLocationCamelRef 

Specifies the application interface for callbacks from the User Location Camel service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 

Returns 
TpAssignmentID 

Raises 

TpCommonExcept ions , P_UNKNOWN_SUBSCRIBER, P_APPLICATION_NOT_ACTIVATED , 
P_INFORMATION_NOT_AVAILABLE , P_INVALID_INTERFACE_TYPE 



8.2.1.2 Method periodicLocationReportingStartReqQ 

Request for periodic mobile location reports on one or several users. 

Returns: assignmentld. 

Specifies the assignment ID of the periodic location-reporting request. 
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Parameters 

appLocationCamel : in IpAppUserLocationCamelRef 

Specifies the application interface for callbacks from the User Location Camel service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 

reportinglnterval : in TpDuration 

Specifies the requested interval in milliseconds between the reports. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_INVALID_REPORTING_INTERVAL, P_UNKNOWN_SUBSCRIBER, 
P_APPLICATION_NOT_ACTIVATED , P_INFORMATION_NOT_AVAILABLE , 
P INVALID INTERFACE TYPE 



8.2.1.3 Method periodicLocationReportingStop() 

This method stops the sending of periodic mobile location reports for one or several users. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 



8.2.1 .4 Method triggeredLocationReportingStartReq() 

Request for user location reports, containing mobile related information, when the location is changed (the report is 
triggered by the location change). 

Returns: assignmentld. 

Specifies the assignment ID of the triggered location-reporting request. 

Parameters 

appLocationCamel : in IpAppUserLocationCamelRef 

Specifies the application interface for callbacks from the User Location Camel service. 

users : in TpAddressSet 

Specifies the user(s) for which the location shall be reported. 
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trigger : in TpLocationTriggerCamel 

Specifies the trigger conditions. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_UNKNOWN_SUBSCRIBER, P_APPLICATION_NOT_ACTIVATED , 
P_INFORMATION_NOT_AVAILABLE , P_INVALID_INTERFACE_TYPE 



8.2.1.5 Method triggeredLocationReportingStop() 

Request that triggered mobile location reporting should stop. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 

8.2.1 .6 Method «new» getNextPeriodicLocationRequestQ 

This method is used by the application to query the request set created with periodicLocationReportingStartReq. Since a 
lot of data can potentially be returned (which might cause problem in the middleware), this method must be used in an 
iterative way. Each method invocation may return part of the total set of requests if the set is too large to return it at 
once. The reset parameter permits the application to indicate whether an invocation to getNextPeriodicLocationRequest 
is requesting more requests from the total set of requests or is requesting that the total set of requests shall be returned 
from the beginning. 

Returns the set of requests and an indication whether all off the requests have been obtained or if more requests are 
available that have not yet been obtained by the application. 

Note that the (maximum) number of items provided to the application is determined by the gateway. 

Parameters 

reset : in TpBoolean 

TRUE: indicates that the application is intended to obtain the set of requests starting at the beginning. 

FALSE: indicates that the application requests the next set of requests that have not (yet) been obtained since the last 
call to this method with this parameter set to TRUE. 

The first time this method is invoked, reset shall be set to TRUE. Following the receipt of a final indication, for the next 
call to this method reset shall be set to TRUE. P_TASK_REFUSED may be thrown if these conditions are not met. 
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Returns 
TpPeriodicLocationRequestSetEntry 

Raises 
TpCommonExceptions 

8.2.1 .7 Method «new» getNextTriggeredLocationRequest() 

This method is used by the application to query the request set created with triggeredLocationReportingStartReq. Since 
a lot of data can potentially be returned (which might cause problem in the middleware), this method must be used in an 
iterative way. Each method invocation may return part of the total set of requests if the set is too large to return it at 
once. The reset parameter permits the application to indicate whether an invocation to 

getNextTriggeredLocationRequest is requesting more requests from the total set of requests or is requesting that the 
total set of requests shall be returned from the beginning. 

Returns the set of requests and an indication whether all off the requests have been obtained or if more requests are 
available that have not yet been obtained by the application. 

Note that the (maximum) number of items provided to the application is determined by the gateway. 

Parameters 

reset : in TpBoolean 

TRUE: indicates that the application is intended to obtain the set of requests starting at the beginning. 

FALSE: indicates that the application requests the next set of requests that have not (yet) been obtained since the last 
call to this method with this parameter set to TRUE. 

The first time this method is invoked, reset shall be set to TRUE. Following the receipt of a final indication, for the next 
call to this method reset shall be set to TRUE. P_TASK_REFUSED may be thrown if these conditions are not met. 

Returns 
TpTriggeredLocationRequestSetEntry 

Raises 
TpCommonExceptions 



8.2.2 Interface Class IpAppUserLocationCamel 

Inherits from: Iplnterface. 

The user location Camel application interface is implemented by the client application developer and is used to handle 
location reports that are specific for mobile telephony users. 
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«lnterface» 
IpAppUserLocationCamel 



locationReportRes (assignmentid : in TpAssignmentID, locations : in TpUserLocationCamelSet) : void 

locationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

periodicLocationReport (assignmentid : in TpAssignmentID, locations : in TpUserLocationCamelSet) : void 

periodicLocationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

triggeredLocationReport (assignmentid : in TpAssignmentID, location : in TpUserLocationCamel, criterion : 
in TpLocationTriggerCamel) : void 

triggeredLocationReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

«new» triggeredReportingEnded (assignmentid : in TpAssignmentID) : void 



8.2.2.1 Method location ReportResQ 

Delivery of a mobile location report. The report is containing mobile-related location information for one or several 
users. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the location-report request. 

locations : in TpUserLocationCamelSet 

Specifies the location(s) of one or several users. 



8.2.2.2 Method location ReportErr() 

This method indicates that the location report request has failed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed location report request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 
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8.2.2.3 Method periodicLocationReport() 

Periodic delivery of mobile location reports. The reports are containing mobile-related location information for one or 
several users. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the periodic location-reporting request. 

locations : in TpUserLocationCamelSet 

Specifies the location(s) of one or several users. 



8.2.2.4 Method periodicLocationReportErr() 

This method indicates that a requested periodic location report has failed. Note that errors only concerning individual 
users are reported in the ordinary periodicLocationReport() message. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed periodic location reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.2.2.5 Method triggeredLocationReport() 

Delivery of a report that is indicating that the user's mobile location has changed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered location-reporting request. 

location : in TpUserLocationCamel 

Specifies the location of the user. 

criterion : in TpLocationTriggerCamel 

Specifies the criterion that triggered the report. 



8.2.2.6 Method triggeredLocationReportErr() 

This method indicates that a requested triggered location report has failed. Note that errors only concerning individual 
users are reported in the ordinary triggeredLocationReport() message. 
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Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed triggered location reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.2.2.7 Method «new» triggeredReportingEnded() 

The user status or user location triggering has stopped because the max life time allowed for this triggering has 
exceeded. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered request. 

8.3 User Status Interface Classes 

The User Status Service (US) provides a general user status service. US allow applications to obtain the status of fixed, 
mobile and IP-based telephony users. 

The US provides the IpUserStatus interface. Most methods are asynchronous, in that they do not lock a thread into 
waiting whilst a transaction performs. In this way, the client machine can handle many more calls, than one that uses 
synchronous message calls. To handle responses and reports, the developer must implement IpAppUserStatus interface 
to provide the callback mechanism. 

8.3.1 Interface Class IpAppUserStatus 

Inherits from: Iplnterface. 

The user-status application interface is implemented by the client application developer and is used to handle user status 
reports. 
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«lnterface» 
IpAppUserStatus 



statusReportRes (assignmentid : in TpAssignmentID, status : in TpUserStatusSet) : void 

statusReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

triggeredStatusReport (assignmentid : in TpAssignmentID, status : in TpUserStatus) : void 

triggeredStatusReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, diagnostic : in 
TpMobilityDiagnostic) : void 

«new» extendedStatusReportRes (assignmentid : in TpAssignmentID, status : in 
TpUserStatusExtendedSet) : void 

«new» extendedStatusReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, 
diagnostic : in TpMobilityDiagnostic) : void 

«new» extTriggeredStatusReport (assignmentid : in TpAssignmentID, status : in TpUserStatusExtended) 
: void 

«new» extTriggeredStatusReportErr (assignmentid : in TpAssignmentID, cause : in TpMobilityError, 
diagnostic : in TpMobilityDiagnostic) : void 

«new» triggeredReportingEnded (assignmentid : in TpAssignmentID) : void 



8.3.1.1 Method statusReportResQ 

Delivery of a report, that is containing one or several user's status. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the status-report request. 

status : in TpUserStatusSet 

Specifies the status of one or several users. 

8.3.1.2 Method statusReportErrO 

This method indicates that the status report request has failed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed status report request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 
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8.3.1 .3 Method triggeredStatusReport() 

Delivery of a report that is indicating that a user's status has changed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered status-reporting request. 

status : in TpUserStatus 

Specifies the status of the user. 



8.3.1 .4 Method triggeredStatusReportErr() 

This method indicates that a requested triggered status reporting has failed. Note that errors only concerning individual 
users are reported in the ordinary triggeredStatusReport() message. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed triggered status reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.3.1 .5 Method «new» extendedStatusReportResQ 

Delivery of a report, that is containing one or several user's status. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the status-report request. 

status : in TpUserStatusExtendedSet 

Specifies the status of one or several users. 

8.3.1 .6 Method «new» extendedStatusReportErr() 

This method indicates that the status report request has failed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed status report request. 
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cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



ETSI TS 129 198-6 V6.6.1 (2006-07) 



8.3.1 .7 Method «new» extTriggeredStatusReport() 

Delivery of a report that is indicating that a user's status has changed. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered status-reporting request. 

status : in TpUserStatusExtended 

Specifies the status of the user. 



8.3.1.8 



Method «new» extTriggeredStatusReportErr() 



This method indicates that a requested triggered status reporting has failed. Note that errors only concerning individual 
users are reported in the ordinary extTriggeredStatusReport() message. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the failed triggered status reporting start request. 

cause : in TpMobilityError 

Specifies the error that led to the failure. 

diagnostic : in TpMobilityDiagnostic 

Specifies additional information about the error that led to the failure. 



8.3.1.9 



Method «new» triggeredReportingEnded() 



The user status or user location triggering has stopped because the max life time allowed for this triggering has 
exceeded. 

Parameters 

assignmentid : in TpAssignmentID 

Specifies the assignment ID of the triggered request. 



8.3.2 Interface Class IpUserStatus 



Inherits from: IpService. 

The application programmer can use this interface to obtain the status of fixed, mobile and IP-based telephony users. 
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This interface shall be implemented by a User Status SCF. 

The statusReportReqO method, or both the triggeredStatusReportingStartReqO and trigggeredStatusReportingStopO 
methods shall be implemented as a minimum requirement. 



«lnterface» 
IpUserStatus 



statusReportReq (appStatus : in IpAppUserStatusRef, users : in TpAddressSet) : TpAssignmentID 

triggeredStatusReportingStartReq (appStatus : in IpAppUserStatusRef, users : in TpAddressSet) : 
TpAssignmentID 

triggeredStatusReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 

«new» getNextTriggeredStatusRequest (reset : in TpBoolean) : TpTriggeredStatusRequestSetEntry 

«new» extendedStatusReportReq (appStatus : in IpAppUserStatusRef, users : in TpAddressSet) : 
TpAssignmentID 

«new» extTriggeredStatusReportingStartReq (appStatus : in IpAppUserStatusRef, users : in 
TpAddressSet) : TpAssignmentID 

«new» extTriggeredStatusReportingStop (stopRequest : in TpMobilityStopAssignmentData) : void 



8.3.2.1 Method StatusReportReqO 

Request for a report on the status of one or several users. 

Returns: assignmentld. 

Specifies the assignment ID of the status-report request. 

Parameters 

appStatus : in IpAppUserStatusRef 

Specifies the application interface for callbacks from the User Status service. 

users : in TpAddressSet 

Specifies the user(s) for which the status shall be reported. 

Returns 
TpAssignmentID 

Raises 

TpCommonExcept ions , P_UNKNOWN_SUBSCRIBER, P_INFORMATION_NOT_AVAILABLE , 
P_APPLICATION_NOT_ACTIVATED , P_INVALID_INTERFACE_TYPE 
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8.3.2.2 Method triggeredStatusReportingStartReq() 

Request for triggered status reports when one or several user's status is changed. The user status service will send a 
report when the status changes. 

Returns: assignmentld. 

Specifies the assignment ID of the triggered status-reporting request. 

Parameters 

appStatus : in IpAppUserStatusRef 

Specifies the application interface for callbacks from the User Status service. 

users : in TpAddressSet 

Specifies the user(s) for which the status changes shall be reported. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_UNKNOWN_SUBSCRIBER, P_INFORMATION_NOT_AVAILABLE , 
P_APPLICATION_NOT_ACTIVATED , P_INVALID_INTERFACE_TYPE 



8.3.2.3 Method triggeredStatusReportingStop() 

This method stops the sending of status reports for one or several users. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 

8.3.2.4 Method «new» getNextTriggeredStatusRequest() 

This method is used by the application to query the request set created with triggeredStatusReportingStartReq. Since a 
lot of data can potentially be returned (which might cause problem in the middleware), this method must be used in an 
iterative way. Each method invocation may return part of the total set of requests if the set is too large to return it at 
once. The reset parameter permits the application to indicate whether an invocation to getNextTriggeredStatusRequest 
is requesting more requests from the total set of requests or is requesting that the total set of requests shall be returned 
from the beginning. 

Returns the set of requests and an indication whether all off the requests have been obtained or if more requests are 
available that have not yet been obtained by the application. 

Note that the (maximum) number of items provided to the application is determined by the gateway. 
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Parameters 

reset : in TpBoolean 

TRUE: indicates that the apphcation is intended to obtain the set of requests starting at the beginning. 

FALSE: indicates that the application requests the next set of requests that have not (yet) been obtained since the last 
call to this method with this parameter set to TRUE. 

The first time this method is invoked, reset shall be set to TRUE. Following the receipt of a final indication, for the next 
call to this method reset shall be set to TRUE. P_TASK_REFUSED may be thrown if these conditions are not met. 

Returns 
TpTriggeredStatusRequestSetEntry 

Raises 
TpCommonExceptions 

8.3.2.5 Method «new» extendedStatusReportReq() 

Request for a report on the status of one or several users. 
A user can be identified by the following address types: 

- MSISDN indicated with address plan P_ADDRESS_PLAN_E164. 

- IP Address indicated with address plan P_ADDRESS_PLAN_IP. 

- User Name indicated with address plan P_ADDRESS_PLAN_UNDEFINED. 
Returns: assignmentlD. 

Parameters 

appStatus : in IpAppUserStatusRef 

Specifies the application interface for callbacks from the User Status service. 

users : in TpAddressSet 

Specifies the user(s) for which the status shall be reported. 

Returns 

TpAs s ignment ID 

Raises 

TpCommonExceptions , P_UNKNOWN_SUBSCRIBER, P_INFORMATION_NOT_AVAILABLE , 
P_APPLICATION_NOT_ACTIVATED , P_INVALID_INTERFACE_TYPE 

8.3.2.6 Method «new» extTriggeredStatusReportingStartReq() 

Request for triggered status reports when one or several user's status is changed. The user status service will send a 
report when the status changes. 

Returns: assignmentld. 

Specifies the assignment ID of the triggered status-reporting request. 
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Parameters 

appStatus : in IpAppUserStatusRef 

Specifies the application interface for callbacks from the User Status service. 

users : in TpAddressSet 

Specifies the user(s) for which the status changes shall be reported. 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions , P_UNKNOWN_SUBSCRIBER, P_INFORMATION_NOT_AVAILABLE , 
P_APPLICATION_NOT_ACTIVATED , P_INVALID_INTERFACE_TYPE 

8.3.2.7 Method «new» extTriggeredStatusReportingStop() 

This method stops the sending of status reports for one or several users. 

Parameters 

stopRequest : in TpMobilityStopAssignmentData 

Specifies how the assignment shall be stopped, i.e. if whole or just parts of the assignment should be stopped. 

Raises 

TpCommonExceptions , P_INVALID_ASSIGNMENT_ID 



9 State Transition Diagrams 

9.1 User Location 

There are no State Transition Diagrams for User Location. 

9.2 User Location Camel 

9.2.1 State Transition Diagrams for IpUserLocationCamel 

During the signServiceAgreement a new user location interface reference is created, which is user as the initial point of 
contact for the application. 
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Figure : State Transition Diagram for User Location Camel 



9.2.1.1 



Active State 



In this state, a relation between the Application and the Network User Location Service Capability Feature has been 
established. It allows the application to request a specific user location reports, subscribe to periodic user location 
reports or subscribe to triggers that generate location report when a location update occurs inside the current VLR area 
or when the user moves to another VLR area or both. 



9.3 



User Status 



9.3.1 State Transition Diagrams for IpUserStatus 
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Figure : State Transition Diagram for User Status 



9.3.1.1 



Active State 



In this state, a relation between the Apphcation and the User Status Service Capabihty Feature has been established. It 
allows the application to request a specific user status report or subscribe to triggers that generate status reports when 
the status of one of the monitored user changes. 



10 Service Properties 

10.1 Mobility Properties 

10.1.1 Emergency Application Subtypes 

Emergency (see definition of 'LCS Client Type' in 3GPP TS 23.271) Application Subtypes; 

This property contains a list of application subtypes that are permitted to use the service. The possible subtypes are (see 
definition of 'LCS CHent Internal ID' in 3GPP TS 23.271): 

- "Broadcast service" 

- "O&M HPLMN service" 

- "O&M VPLMN service" 

- "Anonymous location" 

- "Target MS subscribed service" 

10.1.2 Value Added Application Subtypes 

Value Added (see definition of 'LCS Client Type' in 3GPP TS 23.271) Apphcation Subtypes. 
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This property contains a list of application subtypes that are permitted to use the service. The possible subtypes are (see 
definition of 'LCS Ghent Internal ID' in 3GPP TS 23.271): 

- "Broadcast service" 

- "O&M HPLMN service" 

- "O&M VPLMN service" 

- "Anonymous location" 

- "Target MS subscribed service" 



10.1.3 PLMN Operator Application Subtypes 

PLMN Operator (see definition of 'LCS Ghent Type' in 3GPP TS 23.271.) Apphcation Subtypes. 

This property contains a list of application subtypes that are permitted to use the service. The possible subtypes are (see 
definition of 'LGS Ghent Internal ID' in 3GPP TS 23.271): 

- "Broadcast service" 

- "O&M HPLMN service" 

- "O&M VPLMN service" 

- "Anonymous location" 

- "Target MS subscribed service" 

10.1 .4 Lawful Intercept Application Subtypes 

Lawful Intercept (See definition of 'LGS Ghent Type' in 3GPP TS 23.271.) Application Subtypes. 

This property contains a list of application subtypes that are permitted to use the service. The possible subtypes are (see 
definition of 'LGS Ghent Internal ID' in 3GPP TS 23.271): 

- "Broadcast service" 

- "O&M HPLMN service" 

- "O&M VPLMN service" 

- "Anonymous location" 

- "Target MS subscribed service" 

10.1.5 Altitude Obtainable 

Indicates whether it is possible to obtain a user's altitude. 

10.1.6 Location Methods 

List of supported location methods. Possible values (other values are permitted): 

• "Time of Arrival" 

• "Timing Advance" 

• "GPS" 

• "User Data Lookup" 

• "Any Time Interrogation" 

10.1.7 Priorities 

List of supported priorities for location requests. Possible values (no other values are permitted): 

• "Normal" 
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• "High" 

1 0.1 .8 Max Interactive Requests 

The maximum number of parallel outstanding location or status requests allowed per application. It shall be possible to 
convert the value to a 32-bit integer. 

10.1.9 Max Triggered Users 

The maximum number of users allowed per application for which triggered location reporting can be requested. It shall 
be possible to convert the value to a 32-bit integer. 

10.1.10 Max Periodic Users 

The maximum number of users allowed per application for which periodic location reporting can be requested. It shall 
be possible to convert the value to a 32-bit integer. 

1 0.1 .1 1 Min Periodic Interval Duration 

The minimal time in seconds allowed between two periodic reports. It shall be possible to convert the value to a 32-bit 
integer. Note however that the reportinglnterval parameter, which is used in methods pertaining to periodic location 
reporting, is of common data type TpDuration, i.e. a signed 32-bit integer representing a time interval in milliseconds. 



10.1.12 Initial Report 



Indicates whether a triggered service should generate an initial triggered report immediately after a triggered start 
request. 

• Triggered Status - If this property is set to "True", the initial status of the end user is reported immediately 
after the triggeredStatusReportingStartReq. 

• Triggered Location - If this property is set to "True", the initial location of the end user is reported 
immediately after the triggeredLocationReportingStartReq, if the trigger criteria is met i.e. if the end user is 
within the location area and the Criterion is P_UL_ENTERING_AREA or the end user is outside the 
location area and the Criterion is P_UL_LEAVING_AREA. 

10.1.13 Max Life Time 

Specifies the maximum life time in milliseconds of a triggered or periodic reporting. It is of common data type 
TpDuration, i.e. a signed 32-bit integer representing a time interval in milliseconds. A value of zero means infinite life 
time. 

• The periodic or triggered reporting will stop when a stop method associated with the triggering is received by 
the SCS or when the life time has expired. 

10.2 User Location Service Properties 

A specific User Location service shall set the following properties: 

• General Properties applicable to all SCFs (in Framework) 

• Permitted application types 

• Permitted application subtypes 

• Priorities (see definition of 'LCSChentType' in 3GPP TS 23.271.) 

• Altitude obtainable 
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• Location methods 

• Max interactive requests 

• Max triggered users 

• Max periodic users 

• Min periodic interval duration 

• Initial Report 

• Max Life Time 
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EXAMPLE: 



The example below describes the capabilities of two fictive User Location services: 



Property Name 


Property Value 
Service 1 


Property Value 
Service 2 


Service instance ID 


Ox80923ADO 


OxFOED85CB 


Service name 


UserLocation 


UserLocation 


Service version 


2.1 


2.1 


Service description 


Basic User Location service 


Advanced high-performance User Location service 


Product name 


Find It 


Locate.com 


Product version 


1.3 


3.1 


Supported interfaces 


"IpUserLocation" 


"IpUserLocation" 


Permitted application types 


"Emergency service", "Value added service" 


"Emergency service", "Value added service", "Lawful 
intercept service" 


Permitted application subtypes 


7 


7 


Priorities 


"Normal" 


"Normal", "High" 


Altitude obtainable 


False 


True 


Location methods 


"Timing Advance" 


"GPS", "Time Of Arrival" 


Max interactive requests 


2000 


10000 


Max triggered users 





2000 


Max periodic users 


300 


2000 


Min periodic interval duration 


600 


30 


Initial Report 


True 


True 



10.3 User Location Camel Service Properties 

A specific User Location Camel service shall set the following properties: 

• General Properties applicable to all SCFs (in Framework) 

• Max interactive requests 

• Max triggered users 

• Max periodic users 

• Min periodic interval duration 

• Initial Report 

• Max Life Time 

1 0.4 User Status Service Properties 

A specific User Location service shall set the following properties: 

• General Properties applicable to all SCFs (in Framework) 

• Max interactive requests 



ETSI 



3GPP TS 29.198-06 version 6.6.1 Release 6 



53 



ETSI TS 129 198-6 V6.6.1 (2006-07) 



Max triggered users 
Initial Report 
Max Life Time 



11 



Data Definitions 



All data types referenced but not defined in this clause are common data definitions which may be found in 
3GPPTS 29.198-2. 

1 1 .1 Common Mobility Data Definitions 

The following data definitions are used for several of the mobility services. 

11.1.1 TpGeographicalPosition 

Defines the Sequence of Data Elements that specify a geographical position. 

The horizontal location is defined by an "ellipsoid point with uncertainty shape". The reference system chosen for the 
coding of locations is the World Geodetic System 1984 (WGS 84). 

TypeOfUncertaintyShape describes the type of the uncertainty shape and Longitudel Latitude defines the position of the 
uncertainty shape. The following table defines the meaning of the data elements that describe the uncertainty shape for 
each uncertainty shape type. 



Type of 

uncertainty 

shape 


Uncertainty 
Outer 
Semi 
Major 


Uncertainty 
Outer 
Semi 
Minor 


Uncertainty 
Inner 
Semi 
Major 


Uncertainty 
Inner 
Semi 
Minor 


Angle Of Semi 
Major 


Segment Start 
Angle 


Segment End 
Angle 


None 


- 


- 


- 


- 








Circle 


radius of circle 


- 


- 


- 




- 


- 


Circle Sector 


radius of circle 


- 


- 


- 


- 


start angle of 
circle segment 


end angle of 
circle segment 


Circle Arc 
Stripe 


radius of outer 
circle 


- 


radius of inner 
circle 


- 


- 


start angle of 
circle arc stripe 


end angle of 
circle arc stripe 


Ellipse 


length of semi- 
major axis 


length of semi- 
minor axis 






rotation of 

elhpse 

measured 

clockwise from 

north 






Ellipse 
Sector 


length of semi- 
major axis 


length of semi- 
minor axis 






rotation of 

elhpse 

measured 

clockwise from 

north 


start angle of 
ellipse segment 


end angle of 
elhpse segment 


Ellipse Arc 
Stripe 


length of semi- 
major axis, 
outer ellipse 


length of semi- 
minor axis, 
outer elhpse 


length of semi- 
major axis, 
inner elhpse 


length of semi- 
minor axis, 
inner ellipse 


rotation of 

elhpse 

measured 

clockwise from 

north 


start angle of 

ellipse arc 

stripe 


end angle of 

ellipse arc 

stripe 
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Ai. 








North 


outer 
semi-major 


angle of 

semi major 




axis 
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^^^ 
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Figure 1 Description of an Ellipse Arc 



TpGeographlcalPosltlon : 



Sequence Element Name 


Sequence Element Type 


Longitude 


TpFloat 


Latitude 


TpFloat 


TypeOf Uncertainty Shape 


TpLo c at ionUn certainty Shape 


UncertaintylnnerSemiMa jor 


TpFloat 


UncertaintyOuterSemiMa jor 


TpFloat 


Uncertainty I nnerSemiMinor 


TpFloat 


Uncertainty Out erSemiMinor 


TpFloat 


AngleOf SemiMa jor 


Tplnt32 


Segment St art Angle 


Tplnt32 


Segment EndAngle 


Tplnt32 



11.1.2 TpLocationPriority 

Defines the priority of a location request. 



Name 


Value 


Description 


P_M_NORMAL 





Normal 


P_M_HIGH 


1 


High 
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11.1.3 TpLocationRequest 



Defines the Sequence of Data Elements that specify a location request. 



Sequence Element 
Name 


Sequence Element 
Type 


Description 


RequestedAccuracy 


TpFloat 


Requested accuracy in meters. 


RequestedResponseTime 


TpLocationResponseTime 


Requested response time as a classified requirement or as an absolute timer. 


AltitudeRequested 


TpBoolean 


Altitude request flag. 


Type 


TpLocadonType 


The kind of location that is requested. 


Priority 


TpLocationPriority 


Priority of location request. 


RequestedLocationMethod 


TpString 


The kind of location method that is requested. 



1 1 .1 .4 TpLocationResponselndicator 

Defines a response time requirement. 



Name 


Value 


Description 


P_M_NO_DELAY 





No delay: return either initial or last known location of the user. 


P_M_LOW_DELAY 


1 


Low delay: return the cunent location with minimum delay. The mobility service shall attempt to fulfil 
any accuracy requirement, but in doing so shall not add any additional delay. 


P_M_DELAY_TOLERANT 


2 


Delay tolerant: obtain the cun"ent location with regard to fulfilhng the accuracy requirement. 


P_M_USE_TIMER_VALUE 


3 


Use timer value: obtain the current location with regard to fulfilling the response time requirement. 



11.1.5 TpLocationResponseTime 



Defines the Sequence of Data Elements that specify the application's requirements on the mobility service's 
response time. 



Sequence Element Name 


Sequence Element Type 


Description 


ResponseTime 


TpLocationResponselndicator 


Indicator for which kind of response time that is required, see 
TpLocationResponselndicator. 


TimerValue 


Tplnt32 


Optional timer used in combination when ResponseTime equals 
P_M_USE_TIMER_VALUE. Units are seconds. 



11.1.6 TpLocationType 

Defines the type of location requested. 



Name 


Value 


Description 


P_M_CURRENT 





Cun-ent location 


P_M_CURRENT_OR_LAST_KNOWN 


1 


CuiTent or last known location 


P_M_INITIAL 


2 


Initial location for an emergency services call 
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11.1.7 TpLocationUncertaintyShape 

Defines the type of uncertainty shape. 



Name 


Value 


Description 


P_M_SHAPE_NONE 





No uncertainty shape present. 


P_M_SHAPE_CIRCLE 


1 


Uncertainty shape is a circle. 


P_M_SHAPE_CIRCLE_SECTOR 


2 


Uncertainty shape is a circle sector. 


P_M_SHAPE_CIRCLE_ARC_STRIPE 


3 


Uncertainty shape is a circle arc stripe. 


P_M_SHAPE_ELLIPSE 


4 


Uncertainty shape is an ellipse. 


P_M_SHAPE_ELLIPSE_SECTOR 


5 


Uncertainty shape is an ellipse sector. 


P_M_SHAPE_ELLIPSE_ARC_STRIPE 


6 


Uncertainty shape is an ellipse arc stripe. 



11.1.8 TpMobilityDiagnostic 

Defines a diagnostic value that is reported in addition to an error by one of the mobihty services. 



Name 


Value 


Description 


P_M_NO_INFORMATION 





No diagnostic information present. 
Valid for all type of errors. 


P_M_APPL_NOT_IN_PRIV_EXCEPT_LST 


1 


Apphcation not in privacy exception list. 
Valid for 'Unauthorised Application' error. 


P_M_CALL_TO_USER_NOT_SETUP 


2 


Call to user not set-up. 
Valid for 'Unauthorised Application' error. 


P_M_PRIVACY_OVERRIDE_NOT_APPLIC 


3 


Privacy override not apphcable. 
Valid for 'Unauthorised Apphcation' error. 


P_M_D I SALL_BY„LOCAL„REGULAT_REQ 


4 


Disallowed by local regulatory requirements. 
Valid for 'Unauthorised Apphcation' error. 


P„M_CONGESTION 


5 


Congestion. 
Valid for 'Position Method Failure' error. 


P_M_INSUFFICIENT_RESOURCES 


6 


Insufficient resources. 
Valid for 'Position Method Failure' error. 


P_M_INSUFFICIENT_MEAS_DATA 


7 


Insufficient measurement data. 
Valid for 'Position Method Failure' error. 


P_M_INCONSISTENT_MEAS_DATA 


8 


Inconsistent measurement data. 
Valid for 'Position Method Failure' error. 


P_M_LOC_.PROC_NOT_COMPLETED 


9 


Location procedure not completed. 
Valid for 'Position Method Failure' error. 


P_M_LOC_PROC_NOT_SUPP_BY_USER 


10 


Location procedure not supported by user. 
Vahd for 'Position Method Failure' error. 


P_M_QOS_NOT_ATTAINABLE 


11 


Quality of service not attainable. 
Vahd for 'Position Method Failure' error. 
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11.1.9 TpMobilityError 

Defines an error that is reported by one of the mobility services. 



Name 


Value 


Description 


Fatal 


P_M_OK 





No error occurred while processing tiie request. 


N/A 


P_M_SYSTEM_FAILURE 


1 


System failure. 

The request cannot be handled because of a general problem in the mobihty 

service or the underlying network. 


Yes 


P_M_UNAUTHORIZED_NETWORK 


2 


Unauthorised network. 

The requesting network is not authorised to obtain the user' s binding details, 

location or status. 


No 


P_M_UNAUTHORIZED_APPLICATION 


3 


Unauthorised appUcation. 
The application is not authorised to obtain the user's binding details, location or 

status. 


Yes 


P_M_UNKNOWN_SUBSCRIBER 


4 


Unknown subscriber. 
The user is unknown, i.e. no such subscription exists. 


Yes 


P_M_ABSENT_SUBSCRIBER 


5 


Absent subscriber. 
The user is currently not reachable. 


No 


P_M_POSITION_METHOD_FAILURE 


6 


Position method failure. 
The mobihty service failed to obtain the user's position. 


No 



11.1.10 TpMobilityStopAssignmentData 



Defines the Sequence of Data Elements that specify a request to stop whole or parts of an assignment. 
Assignments are used for periodic or triggered reporting of a user's location or status. 

Note that the parameter 'Users' is optional. If the parameter 'StopScope' is set to P_M_ALL_IN_ASSIGNMENT the 
parameter 'Users' is undefined. If the parameter 'StopScope' is set to P_M_SPECIFIED_USERS, then the assignment 
shall be stopped only for those users specified in the 'Users' list. 



Sequence Element Name 


Sequence Element Type 


Description 


Assignmentld 


TpAssignmentID 


Identity of the assignment that shall be stopped. 


StopScope 


TpMobilityStopScope 


Specify if only a part of the assignment or if all the assignment shall be 
stopped. 


Users 


TpAddressSet 


Optional parameter describing which users a stop request is addressing, 
when only a part of an assignment is to be stopped. 



11.1.11 TpMobilityStopScope 



This enumeration is used in requests to stop mobility reports that are sent from a mobility service to an application. 



Name 


Value 


Description 


P_M_ALL_IN_ASSIGNMENT 





The request concerns all users in an assignment. 


P_M_SPECIFIED_USERS 


1 


The request concerns only the users that are explicitly specified in a list. 



11.1.12 TpTerminalType 

Defines which kind of terminal is used. 



Name 


Value 


Description 


P_M_FIXED 





Fixed terminal. 


P_M_MOBILE 


1 


Mobile terminal. 


P_M_IP 


2 


IP terminal. 
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1 1 .2 User Location Data Definitions 

11.2.1 IpUserLocation 

Defines the address of an IpUserLocation Interface. 

1 1 .2.2 IpUserLocatlonRef 

Defines a Reference to type IpUserLocation . 

1 1 .2.3 IpAppUserLocation 

Defines the address of an IpAppUserLocation Interface. 

1 1 .2.4 IpAppUserLocationRef 

Defines a Reference to type IpAppUserLocation . 

1 1 .2.5 IpTriggeredUserLocation 

Defines the address of an IpTriggeredUserLocation Interface. 

1 1 .2.6 IpTriggeredUserLocationRef 

Defines a Reference to type IpTriggeredUserLocation . 

1 1 .2.7 IpAppTrlggeredUserLocatlon 

Defines the address of an IpAppTriggeredUserLocation Interface. 

1 1 .2.8 IpAppTriggeredUserLocationRef 

Defines a Reference to type IpAppTriggeredUserLocation . 

11.2.9 TpUIExtendedData 

Defines the Sequence of Data Elements that specify a location (extended format). 

The optional vertical location is defined by the data element Altitude, which contains the altitude in meters above sea 
level, and the data element AltitudeAccuracy, which contains the accuracy of the altitude. 



Sequence Element Name 


Sequence Element Type 


Description 


GeographicalPosition 


TpGeographicalPosition 


Specification of a position and an area of uncertainty. 


TerminalType 


TpTerminalType 


Kind of terminal. 


Alt itudeP resent 


TpBoolean 


Flag indicating if the altitude is present. 


Altitude 


TpFloat 


Decimal altitude in meters. 


UncertaintyAltitude 


TpFloat 


Uncertainty of the altitude. 


TimestampP resent 


TpBoolean 


Flag indicating if the timestamp is present. 


Time stamp 


TpDateAndTime 


Timestamp indicating when the position was measured. 


UsedLocationMethod 


TpString 


Specifying which location method was used. 



11.2.10 TpUIExtendedDataSet 

Defines a Numbered Set of Data Elements of TpUIExtendedData. 
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11.2.11 TpUserLocationExtended 



Defines the Sequence of Data Elements that specify the identity and location(s) of a user (extended format). In 
general the data element Locations will contain only one location, but in case of IP-telephony users this data element 
might continue several locations (the locations of all communication end-points, where the user is currently registered). 



Sequence Element Name 


Sequence Element Type 


Description 


UserlD 


TpAddress 


The address of the user. 


StatusCode 


TpMobilityError 


Indicator of enor. 


Locations 


TpDlExtendedDataSet 


Optional hst of locations. If StatusCode is indicating an error, this value is 
undefined. 



11.2.12 TpUserLocationExtendedSet 

Defines a Numbered Set of Data Elements of TpUserLocationExtended. 

11.2.13 TpLocationTrigger 

Defines the Sequence of Data Elements that specify the criteria for a triggered location report to be generated. 
The area is defined by an ellipse. 



Sequence Element Name 


Sequence Element Type 


Description 


Longitude 


TpFloat 


Longitude of the position used in the trigger. 


Latitude 


TpFloat 


Latitude of the position used in the trigger. 


AreaSemiMa jor 


TpFloat 


Semi major of ellipse area used in the trigger. 


AreaSemiMinor 


TpFloat 


Semi minor of ellipse area used in the trigger. 


AngleOf SemiMa jor 


Tplnt32 


Angle of the semi major of the elhpse area used in the trigger. 


Criterion 


TpLocationTriggerCriteria 


Trigger criteria with regard to the eUipse area. 


Reporting Interval 


TpDuration 


Duration between generated location reports. 
Notes: 

• Units are milliseconds. 

• Denotes the minimum time between invocations of 
the IpAppTriggeredUserLocation. 
triggeredLocationReport method, for this specific 
location ellipse area and trigger criterion. 



11.2.14 TpLocationTriggerSet 

Defines a Numbered Set of Data Elements of TpLocationTrigger. 

11.2.15 TpLocationTriggerCriteria 

Defines the criteria that trigger a location report. 



Name 


Value 


Description 


P_UL_ENTERING_AREA 





User enters the area 


P_UL_LEAVING_AREA 


1 


User leaves the area 



11.2.16 TpUserLocation 

Defines the Sequence of Data Element s that specify the identity and location of a user (basic format). 



Sequence Element Name 


Sequence Element Type 


Description 


UserlD 


TpAddress 


The address of the user. 


StatusCode 


TpMobilityError 


Indicator of error. 


GeographicalPosition 


TpGeographicalPosition 


Specification of a position and an area of uncertainty. If StatusCode is 
indicating an error, this value is undefined. 
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11.2.17 TpUserLocationSet 

Defines a Numbered Set of Data Elements of TpUserLocation. 

1 1 .2.1 8 TpTriggered Location RequestSetEntry 

Defines the Sequence of Data Elements that specify a set of triggered requests and an indication whether more triggered 
location requests can be requested. 



Sequence Element Name 


Sequence Element Type 


Description 


Requests 


TpTriggeredLocationRequestSet 


Numbered set of requests. 


Final 


TpBoolean 


Indication whether the set of triggered requests is the 

final set (TRUE) or if there are more triggered requests 

(FALSE). 



1 1 .2.1 9 TpTriggeredLocationRequestSet 

Defines a numbered Set of Data Elements of TpTriggeredLocationRequest. 

1 1 .2.20 TpTriggeredLocationRequest 

Defines the Sequence of Data Elements that specify the criteria relating to triggered location requests. 



Sequence Element Name 


Sequence Element Type 


Users 


TpAddressSet 


Request 


TpLocationRequest 


Assignment ID 


TpAssignment ID 



1 1 .2.21 TpPeriodicLocationRequestSetEntry 

Defines the Sequence of Data Elements that specify a set of triggered requests and an indication whether more periodic 
location requests can be requested. 



Sequence Element Name 


Sequence Element Type 


Description 


Requests 


TpPeriodicLocationRequestSet 


Numbered set of requests. 


Final 


TpBoolean 


Indication whether the set of triggered requests is the 

final set (TRUE) or if there are more triggered requests 

(FALSE). 



1 1 .2.22 TpPeriodicLocationRequestSet 

Defines a numbered Set of Data Elements of TpPeriodicLocationRequest. 

1 1 .2.23 TpPeriodicLocationRequest 

Defines the Sequence of Data Elements that specify the criteria relating to periodic location requests. 



Sequence Element Name 


Sequence Element Type 


Users 


TpAddressSet 


Request 


TpLocationRequest 


Report inglnterval 


TpDuration 


AssignmentID 


TpAssignment ID 
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1 1 .3 User Location Camel Data Definitions 

11.3.1 IpUserLocationCamel 

Defines the address of an IpUserLocationCamel Interface. 

11.3.2 IpUserLocationCamelRef 

Defines a Reference to type IpUserLocationCamel . 

1 1 .3.3 IpAppUserLocationCamel 

Defines the address of an IpAppUserLocationCamel Interface. 

1 1 .3.4 IpAppUserLocationCamelRef 

Defines a Reference to type IpAppUserLocationCamel . 

11.3.5 TpLocationCelllDOrLAI 

This data type is identical to a TpString. It specifies the Cell Global Identification or the Location Area Identification 
(LAI). 

The Cell Global Identification (CGI) is defined as a string of characters in the following format: 

MCC-MNC-LAC-CI 
where: 

MCC Mobile Country Code (three decimal digits) 

MNC Mobile Network Code (two or three decimal digits) 

LAC Location Area Code (four hexadecimal digits) 

CI Cell Identification (four hexadecimal digits) 

The Location Area Identification (LAI) is defined as a string of characters in the following format: 

MCC-MNC-LAC 
where: 

MCC Mobile Country Code (three decimal digits) 

MNC Mobile Network Code (two or three decimal digits) 

LAC Location Area Code (four hexadecimal digits) 

The length of the parameter indicates, which format is used. See 3GPP TS 29.002 [4] for the detailed coding. 

1 1 .3.6 TpLocationTriggerCamel 

Defines the Sequence of Data Elements that specify the criteria for a triggered location report to be generated. 



Sequence Element Name 


Sequence Element Type 


Description 


UpdatelnsideVlr 


TpBoolean 


Generate location report, when a location update occurs inside the current 
VLR area. 


UpdateOutsideVlr 


TpBoolean 


Generate location report, when the user moves to another VLR area. 
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1 1 .3.7 TpUserLocationCamel 



Defines the Sequence of Data Elements that specify the location of a mobile telephony user. Note that if the 
StatusCode is indicating an error , then neither GeographicalPosition, Timestamp, VlrNumber, 
LocationNumber, CellldOrLai nor their associated presence flags are defined. 



Sequence Element Name 


Sequence Element Type 


Description 


UserlD 


TpAddress 


The address of the user. 


StatusCode 


TpMobilityError 


Indicator of error. 


GeographicalPositionPresent 


TpBoolean 


Flag indicating if the geographical position is present. 


GeographicalPosition 


TpGeographicalPosition 


Specification of a position and an area of uncertainty. 


TimestampPresent 


TpBoolean 


Flag indicating if the timestamp is present. 


Timestamp 


TpDateAndTime 


Timestamp indicating when the request was processed. 


VlrNumberPresent 


TpBoolean 


Flag indicating if the VLR number is present. 


VlrNumber 


TpAddress 


Current VLR number for the user. 


LocationNumberPresent 


TpBoolean 


Flag indicating if the location number is present. 


LocationNumber (see Note) 


TpAddress 


Current location number. 


CellldOrLaiPresent 


TpBoolean 


Flag indicating if cell-id or LAI of the user is present. 


CellldOrLai 


TpLocationCelllDOrLAI 


Cell-id or LAI of the user. 


NOTE: The location number is tlie number to tlie MSC or in rare cases the roaming number. | 



1 1 .3.8 TpUserLocationCamelSet 

Defines a Numbered Set of Data Elements of TpUserLocationCamel. 

1 1 .4 User Location Emergency Data Definitions 

11.4.1 IpUserLocationEmergency 

Defines the address of an IpUserLocationEmergency Interface. 

1 1 .4.2 IpUserLocationEmergencyRef 

Defines a Reference to type IpUserLocationEmergency . 

1 1 .4.3 IpAppUserLocationEmergency 

Defines the address of an IpAppUserLocationEmergency Interface. 

1 1 .4.4 IpAppUserLocationEmergencyRef 

Defines a Reference to type IpAppUserLocationEmergency . 

11.4.5 TpllVIEI 

This data type is identical to a TpString. It specifies the International Mobile Equipment Identity (IMEI). 

11.4.6 TpNaESRD 

This data type is identical to a TpString. It specifies the North American Emergency Services Routing Digits (NA- 

ESRD). 

NA-ESRD is a telephone number in the North American Numbering Plan that can be used to identify a North American 

emergency services provider and its associated Location Services client. The NA-ESRD also identifies the base station, 

cell site or sector from which a North American emergency call originates. 
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11.4.7 TpNaESRK 



This data type is identical to a TpString. It specifies the North American Emergency Services Routing Key (NA- 

ESRK). 

NA-ESRK is a telephone number in the North American Numbering Plan that is assigned to an emergency services call 

for the duration of the call. The NA-ESRK is used to identify (e.g. route to) both, the emergency services provider and 

the switch, currently serving the emergency caller. During the lifetime of an emergency services call, the NA-ESRK 

also identifies the calling subscriber. 



1 1 .4.8 TpUserLocationEmergencyRequest 



Defines the Sequence of Data Elements that specify the request for the location of an emergency service user. 
The emergency service user is identified by a combination of user address, NaESRD, NaESRK and IMEI. NaESRD, 
NaESRK and IMEI may be provided, if the emergency service user has originated the emergency service call in North 
America. 



Sequence Element Name 


Sequence Element Type 


Description 


UserAddressP resent 


TpBoolean 


Flag indicating if tiie user address is present. 


UserAddress 


TpAddress 


The address of the user. 


NaEsrdP resent 


TpBoolean 


Flag indicating if the NaESRD is present. 


NaEsrd 


TpNaESRD 


Current NaESRD for the user. 


NaEsrkPresent 


TpBoolean 


Flag indicating if the NaESRK is present. 


NaEsrk 


TpNaESRK 


Current NaESRK for the user. 


ImeiPresent 


TpBoolean 


Flag indicating if the IMEI is present. 


Imei 


TpIMEI 


IMEI for the user. 


LocationReq 


TpLocationRequest 


The actual location request. 



1 1 .4.9 TpUserLocationEmergency 



Defines the Sequence of Data Elements that specify the identity and location of an emergency service user. 

The emergency service user is identified by a combination of UserlD, NaESRD, NaESRK and IMEI. 

NaESRD, NaESRK and IMEI may be provided, if the emergency service user has originated the emergency service call 

in North America. 

The horizontal location is defined by an "ellipsoid point with uncertainty ellipse" (see TpUlExtendedData). 



Sequence Element Name 


Sequence Element Type 


Description 


StatusCode 


TpMobilityError 


Indicator of error. 


UserldPresent 


TpBoolean 


Flag indicating if the user address is present. 


Userld 


TpAddress 


The user address. 


NaEsrdP resent 


TpBoolean 


Flag indicating if the NaESRD is present. 


NaEsrd 


TpNaESRD 


Current NaESRD for the user. 


NaEsrkPresent 


TpBoolean 


Flag indicating if the NaESRK is present. 


NaEsrk 


TpNaESRK 


Current NaESRK for the user. 


ImeiPresent 


TpBoolean 


Flag indicating if the IMEI is present. 


Imei 


TpIMEI 


IMEI for the user. 


TriggeringEvent 


TpUserLocationEmergency Trigger 


The reason for this location report. 


GeographicalPos it ionP resent 


TpBoolean 


Flag indicating if the geographical position is present. 


GeographicalPosition 


TpGeographicalPosition 


Specification of a position and an area of uncertainty. 


Alt itudeP resent 


TpBoolean 


Flag indicating if the altitude is present. 


Altitude 


TpFloat 


Decimal altitude in meters. 


UncertaintyAltitude 


TpFloat 


Uncertainty of the altitude. 


TimestampP resent 


TpBoolean 


Flag indicating if a timestamp is present. 


Time St amp 


TpDateAndTime 


Timestamp indicating when the request was processed. 


UsedLocationMethod 


TpString 


Specifying which location method was used. 
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11.4.10 TpUserLocationEmergencyTrigger 

Defines which event triggered the emergency User Location report. 



Name 


Value 


Description 


P_ULE_CALL_ORIGINATION 





An emergency service user originated an emergency call. 


P_ULE_CALL_RELEASE 


1 


An emergency service user released an emergency call. 


P_ULE_LOCATION_REQUEST 


2 


The report is a response to an emergency location report request. 



1 1 .5 User Status Data Definitions 

11.5.1 IpUserStatus 

Defines the address of an IpUserStatus Interface. 

1 1 .5.2 IpUserStatusRef 

Defines a Reference to type IpUserStatus . 

1 1 .5.3 IpAppUserStatus 

Defines the address of an IpAppUserStatus Interface. 

1 1 .5.4 IpAppUserStatusRef 

Defines a Reference to type IpAppUserStatus . 

1 1 .5.5 IpUserStatus 

Defines the Sequence of Data Elements that specify the identity and status of a user. 



Sequence Element Name 


Sequence Element Type 


Description 


UserlD 


TpAddress 


The user address. 


StatusCode 


TpMobilityError 


Indicator of error. 


Status 


TpUser St at us Indicator 


The current status of the user. 


Terminal Type 


TpTerminalType 


The kind of terminal used by the user. 



11.5.6 TpUserStatusSet 

Defines a Numbered Set of Data Elements of TpUserStatus. 



1 1 .5.7 TpUserStatus Indicator 



Defines the status of a user. 



Name 


Value 


Description 


P_US_REACHABLE 





User is reachable 


P_US_NOT_REACHABLE 


1 


User is not reachable 


P_US_BUSY (see Note) 


2 


User is busy (only applicable for interactive user status request, not when triggers are used) 


NOTE: Only applicable to mobile (Camel) telephony users. | 
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1 1 .5.8 TpTriggeredStatusRequestSetEntry 



Defines the Sequence of Data Elements that specify a set of triggered requests and an indication whether more triggered 
status requests can be requested. 



Sequence Element Name 


Sequence Element Type 


Description 


Requests 


TpTriggeredStatusRequestSet 


Numbered set of requests. 


Final 


TpBoolean 


Indication whether the set of triggered requests is the 

final set (TRUE) or if there are more triggered requests 

(FALSE). 



1 1 .5.9 TpTriggeredStatusRequestSet 

Defines a numbered Set of Data Elements of TpTriggeredStatusRequest. 

11.5.10 TpTriggeredStatusRequest 

Defines the Sequence of Data Elements that specify the criteria relating to triggered status requests. 



Sequence Element Name 


Sequence Element Type 


Users 


TpAddressSet 


AssignmentID 


TpAssignmentID 



11.5.11 TpUserStatusExtended 



Defines the Sequence of Data Elements that specify the identity and status of a user. 



Sequence Element Name 


Sequence Element Type 


Description 


UserlD 


TpAddress 


The user address. 


StatusCode 


TpMobilityError 


Indicator of error. 


Status 


TpUserStatusIndicatorExtended 


The current status of the user. 


TerminalType 


TpTerminalType 


The kind of terminal used by the user. 


AuthenticationStatus 


TpAuthStatus Indicator 


The current authentication status of the user 


NetworkStatus 


TpNet wo rkSt at us Indicator 


Country code. Mobile network code, technology and Roaming 
status. 


UserlPAddress 


TpString 


The allocated IP address for the user. 

If there is no IP Address allocated then this is represented with 

the empty string. 


UserMSISDN 


TpString 


The user MSISDN. If the MSISDN address is not known, then 
this is represented with the empty string. 


Userinf o 


TpUserlnfo 


Used to reference the user name and password supplied by the 

user during user-network authentication, if known by the 

network. 


UserConnectionID 


TpString 


Combination of User IP Address and TCP port. This 
combination uniquely identifies the user's TCP connection, 
because one user can have several TCP connections ongoing 

at the same time. The User IP Address contained in 
UserConnectionID can be the same as the userIP Address, but 
this is not always the case since a router in the data network 

might have translated the UserlPAddress to another IP- 
address. The latter is then contained in UserConnectionID. 


AccessPointName 


TpString 


Provides the Access Point Name of the Internet Service 
Provider 



11.5.12 TpUserStatusExtendedSet 

Defines a Numbered Set of Data Elements of TpUserStatusExtended. 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 



66 



ETSI TS 129 198-6 V6.6.1 (2006-07) 



11 .5.1 3 TpUserStatuslndicatorExtended 

Defines the status of a user. 



Sequence Element Name 


Sequence Element Type 


Description 


UserStatusIndicator 


TpUser St at us Indicator 


Indication wiietiier tiie user is busy, reachable or not reachable 


PDPContext Active 


TpBoolean 


Indication whether the user currently has an ongoing data 
session (i.e. PDP context established) 



11.5.14 TpAuthStatuslndicator 

Used to indicate if and how the user has been authenticated during data session establishment 



Name 


Value 


Description 


P_AUTHENTICATED_FOR_NETWORK_ONLY 





Authenticated only for the network 


P_AUTHENTICATED_FOR_NETWORK_AND_IP_SERVICES 


1 


Authenticated for the network and IP services 


P„NOT_AUTHENTICATED 


2 


Not authenticated 



11.5.15 TpUserlnfo 

Used to reference the user name and password supplied by the user, if known by the network. 



Name 


Structure Element Type 


Description 


UserName 


TpString 


User name as provided in a PPP/CHAP message. 


Password 


TpString 


Password as provided in a PPP/CHAP message. 



1 1 .5.1 6 TpNetworkStatuslndicator 



Specifies the country code, mobile network code, access network technology used by the user for the data session and 
roaming status. 



Name 


Structure Element Type 


Description 


CountryCode 


TpString 


Network CC Identification, Country code 


MobileNetworkCode 


TpString 


Network MNC Identification, Mobile network code 


AccessTechnology 


TpAc cess Techno logy 


Network access technology used by the user to connect 


Roaming St at us 


TpRoamingStatus 


Roaming Status 



11.5.17 TpAccessTechnology 

Defines the derived access technology utilised by the user. 



Name 


Value 


Description 


P_MOBILE„ACCESS_PS 





Access via packet switched connection in mobile network 


P„MOBILE„ACCESS„CS 


1 


Access via a circuit switched connection in mobile network 


P_FIXED_ACCESS 


2 


Access via a fixed network 



11.5.18 TpRoamingStatus 

Defines the roaming status of the user. 



£75/ 



3GPP TS 29.198-06 version 6.6.1 Release 6 



67 



ETSI TS 129 198-6 V6.6.1 (2006-07) 



Name 


Value 


Description 


P_UNKNOWN_ROAMING_STATUS 





No infonnation on Roaming status has been found 


P_HOME_USER 


1 


User is in the home network 


P_NAT I ONAL_ROAMI NG 


2 


User has roamed to another operator in the same country 


P_INTERNATIONAL_ROAMING 


3 


User has roamed to another operator abroad 


P_OPERATOR_ROAMING 


4 


User has roamed to a partner operator abroad 



1 1 .6 User Binding Data Definitions 

11.6.1 TpBlndingSet 

Defines a Numbered Set of Data Elements of TpBindingEntrySet. 

11.6.2 TpBindingEntrySet 

Defines a Numbered Set of Data Elements of TpBindingEntry. 

11.6.3 TpBindingEntry 

Defines the Tagged Choice of Data Elements that specifies binding information. 





Tag Element Type 






TpBindingEntryType 





Tag Element Value 


Choice Element 
Type 


Choice Element 
Name 


Description 


P_UB_EXPIRES 


Tplnt32 


UBExpires 


This field can be used to enforce time limits on session 
duration and is defined as an integral number of 
seconds. 


P_UB_CONTACT_ADDRESS 


TpAddress 


UBCont act Address 


This field informs the network of the subscriber's 
desired binding address. 


P_UB_PREFERENCE 


TpFloat 


UBPref erence 


This field conveys a relative order among subscriber 
bindings. 



1 1 .6.4 TpBindingEntryType 

Defines the type of binding information. 



Name 


Value 


Description 


P_UB_UNDEFINED 





Undefined 


P_UB_EXPIRES 


1 


A number indicating the number of seconds the binding is valid 


P_UB_CONTACT_ADDRESS 


2 


The address representing the user's contact address 


P_UB_PREFERENCE 


3 


A number between and 1 indicating the contact address' relative 
preference 



1 1 .6.5 TpBindingNotificationCriteriaSet 

Defines a Numbered Set of Data Elements of TpBindingNotificationCriteria. 
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1 1 .6.6 TpBindingNotificationCriteria 



Defines the Sequence of Data Elements that specifies the criteria relating to binding report requests. 



Sequence Element Name 


Sequence Element Type 


Not i f icationCr iter iaType 


TpBindingNotificationCriteriaType 


ContactAddressSet 


TpAddressSet 



1 1 .6.7 TpBindingNotificationCriteriaType 

Defines the binding operations to be reported. The values may be combined by a logical 'OR' function. 



Nama 


Value 


Description 


P_UB_NEW 


1 


Indicates attempt to create a new binding 


P_UB_REMOVE 


2 


Indicates removal of an existing binding 


P_UB_UPDATE 


4 


Indicates attempt to update an existing binding 



1 1 .7 Units and Validations of Parameters 

This clause describes the units that shall be used for data elements, where this is not obvious. 

Altitude 
Unit: Metric meter 

Angle 
Unit: Degrees 

Value constraint: < 'Angle ' < 3 6 

AreaSemlMajor and AreaSemiMinor 
Unit: Metric meter 

Value constraint: < 'AreaSemi... ' 

Reporting Interval 
Unit: Milliseconds 

Value constraint: < 'Reportinglnterval ' 

UncertaintyAltitude 
Unit: Metric meter 

Value constraint: < 'UncertaintyAltitude ' 

Semantic: (Altitude - UncertaintyAltitude) < 'Terminal actual altitude' < 
('Altitude' + 'UncertaintyAltitude') 

UncertaintylnnerSemiMajor and UncertaintylnnerSemiMinor 
Unit: Metric meter 

Value constraint: < 'Uncertaintylnner... ' 

UncertaintyOuterSemiMajor and UncertaintyOuterSemiMinor 
Unit: Metric meter 

Value constraint: < 'Uncertaintylnner... ' 
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UsedLocatlonMethod 

Predefined strings are listed in clause Location Methods. 



12 Exception Classes 



The following are the list of exception classes which are used in this interface of the API. 



Name 


Description 


P_INVALID_REPORTING_INTERVAL 


The requested reporting interval is not valid 


P_REQUESTED_ACCURACY_CANNOT_BE_DELIVERED 


The requested location accuracy cannot be delivered 


P_REQUESTED_RESPONSE_TIME_CANNOT_BE_DELIVERED 


The requested response time cannot be delivered 


P_TRIGGER_CONDITIONS_NOT_SUBSCRIBED 


Trigger conditions not subscribed 



Each exception class contains the following structure: 



Structure Element Name 


Structure Element Type 


Structure Element Description 


Extrainf ormation 


TpString 


Carries extra information to help identify the source of the 
exception, e.g. a parameter name 
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Annex A (normative): 

OMG IDL Description of IVIobility SCF 

The OMG IDL representation of this interface specification is contained in a text file (mm.idl contained in archive 
2919806V660IDL.ZIP) which accompanies the present document. 
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Annex B (informative): 

W3C WSDL Description of IVIobility SCF 

The W3C WSDL representation of this interface specification is contained in zip file 2919806V660WSDL.ZIP, which 
accompanies the present document. 
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Annex C (informative): 

Java API Description of the IVIobility SCFs 

The Java API realisation of this interface specification is produced in accordance with the Java ReaHsation rules defined 
in Part 1 of this specification. These rules aim to deliver for Java, a developer API, provided as a realisation, supporting 
a Java API that represents the UML specifications. The rules support the production of both J2SE and J2EE versions of 
the API from the common UML specifications. 

The J2SE representation of this interface specification is provided as Java Code, contained in archive 
2919806V660J2SE.ZIP that accompanies the present document. 

The J2EE representation of this interface specification is provided as Java Code, contained in archive 
2919806V660J2EE.ZIP that accompanies the present document. 
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Annex D (informative): 

Description of IVIobility SCF for 3GPP2 cdma2000 networks 

This annex is intended to define the OSA API Stage 3 interface definitions and it provides the complete OSA 
specifications. It is an extension of OSA API specifications capabilities to enable operation in cdma2000 systems 
environment. They are in alignment with 3GPP2 Stage 1 requirements and Stage 2 architecture defined in 

[1] 3GPP2 P.SOOOl-B: "Wireless IP Network Standard", Version 1.0, September 2000; 

[2] 3GPP2 S.R0037-0: "IP Network Architecture Model for cdma2000 Spread Spectrum Systems", 

Version 2.0, May 14, 2002; 

[3] 3GPP2 X.S0013: "All-IP Core Network Multimedia Domain", December 2003. 

These requirements are expressed as additions to and/or exclusions from the 3GPP Release 6 specification. The 
information given here is to be used by developers in 3GPP2 cdma2000 network architecture to interpret the 3GPP 
OSA specifications. 



D.1 General Exceptions 



The terms 3GPP and UMTS are not applicable for the cdma2000 family of standards. Nevertheless these terms are used 
(3GPP TR 21.905) mostly in the broader sense of "3G Wireless System". If not stated otherwise there are no additions 
or exclusions required. 

CAMEL and CAP mappings are not applicable for cdma2000 systems. 



D.2 Specific Exceptions 
D.2.1 Clause 1: Scope 

There are no additions or exclusions. 

D.2.2 Clause 2: References 

Normative references on 3GPP TS 23.078 and on 3GPP TS 29.078 are not applicable for cdma2000 systems. 

D.2. 3 Clause 3: Definitions and abbreviations 

There are no additions or exclusions. 

D.2.4 Clause 4: Mobility SCF 

There are no additions or exclusions. UL-User Location UMTS term may be mapped onto LCS-Location Services 
cdma2000 term. CAMEL is not applicable for cdma2000 systems. 

D.2. 5 Clause 5: Sequence Diagrams 

There are no additions. User Location Camel Sequence Diagrams are not applicable for cdma2000 systems. 
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D.2.6 Clause 6 Class Diagrams 

There are no additions. User Location Camel Class Diagrams are not applicable for cdma2000 systems. 

D.2.7 Clause 7: The Service Interface Specifications 

There are no additions or exclusions. 

D.2.8 Clause 8: Mobility Interface Classes 

There are no additions. User Location Camel Interface Classes are not applicable for cdma2000 systems 

D.2.9 Clause 9: State Transition Diagrams 

Since CAMEL protocol is not applicable for cdma2000 systems, User Location Camel state transition diagrams are not 
applicable for cdma2000 systems. 

D.2.10 Clause 10: Service Properties 

Since CAMEL protocol is not applicable for cdma2000 systems, an SCS shall indicate support for the CAMEL feature 
through service properties. For cdma2000 systems the service properties shall be disabled (CAMEL shall be turned 
always off in the case of the 3GPP2 networks; e.g.: UserLocationCamel shall be set to false). 

D.2.1 1 Clause 1 1 : Data Definitions 

There are no additions. UserLocationCamel data definitions are not applicable for cdma2000 systems. 

D.2.1 2 Clause 12: Exception Classes 

There are no additions or exclusions. 

D.2.1 3 Annex A (normative): OMG IDL Description of Mobility SCF 

There are no additions or exclusions. 

D.2.1 4 Annex B (informative): W3C WSDL Description of Mobility 
SCF 

There are no additions or exclusions. 

D.2.1 5 Annex C (informative): Java™ API Description of Mobility 
SCF 

There are no additions or exclusions. 
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Annex E (informative): 
Change history 



Change history 


Date 


TSG# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


Mar 2001 


CN 11 


NP-010134 


0047 




CR 29.1 98: for moving TS 29.1 98 from R99 to Pel 4 (N5-01 01 58) 


3.2.0 


4.0.0 


Jun2001 


CN 12 


NP-010330 


0001 


- 


Corrections to OSA API Rel4 


4.0.0 


4.1.0 


Jul 2001 










291 98-06-41 0.zip archive was packaged with the wrong 
accompanying IDL zip file, which should be mm.idi 
and not Call Control IDLs (04). 


4.1.0 


4.1.1 


Sep 2001 


CN 13 


NP-010520 


0002 


- 


Changing references to JAIN 


4.1.1 


4.2.0 


Sep 2001 


CN 13 


NP-010520 


0003 


- 


Introduction of missing mobility exceptions 


4.1.1 


4.2.0 


Oct 2001 


- 


- 


- 


- 


Correction to ToC 


4.2.0 


4.2.1 


Dec 2001 


CN 14 


NP-010599 


0004 


- 


Replace Out Parameters with Return Types 


4.2.1 


4.3.0 


Dec 2001 


CN_14 


NP-010599 


0005 


— 


Methods accepting an interface as a parameter need to be able to 
raise P INVALID INTERFACE TYPE 


4.2.1 


4.3.0 


Dec 2001 


CN 14 


NP-010599 


0006 


- 


Correction of references to 3GPP specifications 


4.2.1 


4.3.0 


Dec 2001 


CN_14 


NP-010599 


0007 


- 


Correction to callback interface reference in method 
IpTriggeredUserLocation.triggeredLocationReportingStartReq 


4.2.1 


4.3.0 


Mar 2002 


CN_15 


NP-020108 


0008 


- 


Add P_INVALID_INTERFACE_TYPE exception to 
IpService.setCallbackO and lpService.setCallbackWithSessionlD() 


4.3.0 


4.4.0 


Jun 2002 


CN 16 


NP-020181 


0009 


- 


Addition of support for Java API technology realisation 


4.4.0 


5.0.0 


Jun 2002 


CN 16 


NP-020182 


0010 


- 


Addition of support for WSDL realisation 


4.4.0 


5.0.0 


Jun 2002 


CN_16 


NP-020190 


0011 


- 


Delete the repetitive description of 

P APPLICATION NOT ACTIVATED and other exceptions 


4.4.0 


5.0.0 


Jun 2002 


CN_16 


NP-020190 


0012 


- 


Correcting type of assignmentID parameters from TpSessionID to 
TpAssignmentID 


4.4.0 


5.0.0 


Jun 2002 


CN 16 


NP-020190 


0013 


- 


Correcting erroneous references to Service Factory 


4.4.0 


5.0.0 


Sep 2002 


CN 17 


NP-020433 


0014 


- 


Remove all parameter error and network error sequence diagrams 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020433 


0015 




Removal of unnecessary exception from 
IpUserLocation.LocationReportReqO, 
IpUserLocation.extendedLocationReportReqO, 
IpUserLocation.periodicLocationReportingStartReqO 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020433 


0016 


— 


Remove unusable exceptions from 
IpUserLocationCamel.periodicLocationReportingStartReqO 


5.0.0 


5.1.0 


Sep 2002 


CN 17 


NP-020433 


0017 


- 


Add text to clarify requirements on support of methods 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020395 


0018 


- 


Add text to clarify relationship between 3GPP and ETSI/Parlay OSA 
specifications 


5.0.0 


5.1.0 


Mar 2003 


CN 19 


NP-030022 


0020 




Addition of status of methods to Mobility interfaces 


5.1.0 


5.2.0 


Jun 2003 


CN_20 


NP-030249 


0021 


- 


Add methods to prevent unnecessary strict requirements on 
application persistency for Mobility 


5.2.0 


6.0.0 


Jun 2003 


CN 20 


NP-030249 


0022 


- 


Extension to User Status 


5.2.0 


6.0.0 


Dec 2003 


CN 22 


NP-030553 


0024 


- 


Add OSA API support for 3GPP2 networks 


6.0.0 


6.1.0 


Jun 2004 


CN_24 


NP-040270 


0026 


- 


Correct alignment between ETSI/Parlay OSA and the 3GPP OSA by 
adding user binding data types 


6.1.0 


6.2.0 


Sep 2004 


CN 25 


NP-040354 


0028 


- 


Correction to Java Realisation Annex 


6.2.0 


6.3.0 


Sep 2004 


CN 25 


NP-040358 


0029 


- 


Support High Availability at API Level 


6.2.0 


6.3.0 


Dec 2004 


CN 26 


NP-040485 


0053 


- 


Removal of OSA API SCFs description in W3C WSDL 


6.3.0 


6.4.0 


Dec 2004 


-- 


- 


- 


- 


Some figures were not visible (deleted 2/3 SoDAError bookmarks) 


6.4.0 


6.4.1 


Dec 2004 


-- 


- 


- 


- 


Added missing code attachments 


6.4.0 


6.4.1 


Dec 2005 


CP 30 


CP-050561 


0056 


- 


Correct definition of time duration units and usage 


6.4.1 


6.5.0 


Dec 2005 


CP 30 


CP-050563 


0059 


- 


Correction to allow generation of an immediate triggered report 


6.4.1 


6.5.0 


Jun 2006 


CT 32 


CP-060194 


0060 


- 


Resubmission of OSA API SCFs description in W3C WSDL 


6.5.0 


6.6.0 


Jun 2006 


CT 32 


CP-060196 


0061 


- 


Add missing life time timer for triggeredStatusReportingStartReq 


6.5.0 


6.6.0 


Jul 2006 


-- 
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- 


- 


Added missing code attachments 


6.6.0 


6.6.1 
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